axios 二次封装使用

前端添加文件夹axios并建立index文件
在这里插入图片描述
然后index.js如下

import axios from 'axios'
import router from '../router'
import qs from 'qs'
// 5s后请求不到数据 请求超时
// axios.defaults.timeout=5000
// 处理post数据格式
axios.defaults.headers.post['Content-Type']='application/x-www-form-urlencoded;charset=UTF-8'
// 路径设置
// axios.defaults.baseURL=' http://localhost:8080'
// 跨域时设置cookie
axios.defaults.withCredentials = true
// 封装get post 方法

// get
export default{
  get(url, params) {
    return new Promise((resolve, reject) => {
      axios.get(url, {
          params: params
        })
        .then(response => {
          resolve(response);
        })
        .catch(err => {
          reject(err);
        })
    })
},
// post 
 post(url,params){
  return new Promise((resolve,reject)=>{
    axios({
      url,
      method:'post',
      transformRequest: [function (data) {
        // 对 data 进行任意转换处理
        return qs.stringify(data)
    }],
    data:params
    }).then(res=>{
      resolve(res)
    }).catch(err=>{
      reject(err)
    })
  })
  },

然后我对前端的整个数据接口放在了api文件夹下统一管理;这里就引用封装好的post和get方法。
在这里插入图片描述
common.js为管理url头部路径。
在这里插入图片描述
这里示例展示一下前后端交互

import {getList} from "../../api/index";//引用以上前端写好的接口
export default {
  data() {
    return {};
  },
  created() {
    this.bookList();
  },
  methods: {
    bookList() {
      getList({
        bookName: "marry"
      })//向后台传递参数
        .then(res => {
          if (res.status === 200) {
            console.log(res.data.result)
          }
        })
        .catch(err => {
          console.log(err);
        });
    },
  }
};
</script>

后台接收参数:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
以及后端congfig配置添加
在这里插入图片描述

const config = exports = {
    // 数据库配置
    mysql: {
      client: {
        host: 'localhost',
        port: '3306',
        user: 'root',
        password: 'root',
        database: 'mysqls',
        multipleStatements: true,
      },
      app: true,
      agent: false,
    },
    security: {
      csrf: {
        enable: false, // 前后端分离,post请求不方便携带_csrf
        ignoreJSON: true,
      },
      domainWhiteList: [ 'http://localhost:8080', 'http://192.168.109.1:8080' ], // 允许访问白名单
    },
    cors: {
      // origin: 'http://localhost:8080',
      credentials: true, // 允许跨域请求携带cookies
      allowMethods: 'GET,HEAD,PUT,POST,DELETE,PATCH',
    },

}

下期内容:
登录验证 中间件使用

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值