React的前期准备工作

请求前后的过滤和响应前后的拦截操作都在这里定义

以及对axios的封装也写在一起

编写Request.js文件,在其中完成对请求的所有操作

import axios from "axios";
import {message} from "antd";
axios.defaults.withCredentials=true
// 第一步,创建实例
export const service = axios.create();
// 第二步,请求拦截
service.interceptors.request.use(
    function (config) {
        // 请求发生前处理
        config.headers = {
            // 每次请求前带上Token
            token: window.localStorage.getItem("token")
        }
        return config;
    }, function (error) {
        // 请求错误处理
        console.log(error)
        message.error("服务器被吃了!!")
        console.log("请求错误之后"+error)
        return Promise.reject(error);
    }
);
// 第三步,响应阻拦
service.interceptors.response.use(
    function (response) {
        return response.data;
    }, function (error) {
        // 响应错误处理
        console.log("服务器被吃了!!")
        message.error("服务器被吃了!!")
        return Promise.reject(error);
    }
);
//万一添加前置路径 可变更
//封装请求
export const postRequest=(url,parmes)=>{
    return service.request({
        method:"post",
        url:url,
        data: parmes
    })
}
// 传送json的put请求
export const putRequest = (url, params) => {
    return service.request({
        method: 'put',
        url: url,
        data: params
    })
}
// 传送json的get请求
export const getRequest = (url, params) => {
    return service.request({
        method: 'get',
        url: url,
        data: params
    })
}
// 传送json的delete请求
export const deleteRequest = (url, params) => {
    return service.request({
        method: 'delete',
        url: url,
        data: params
    })
}

创建Api.js

将所有请求方法的调用封装在一起

import {postRequest} from "./Request"
let baseUrl = "http://localhost:8080"
//获取验证码
function getCaptcha(){
    return baseUrl+`/captcha?id=` + Math.random();
}
//登录方法
function loginApi(values){
    return postRequest(baseUrl+"/login", values)
}
export{
    loginApi,
    getCaptcha
}

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LeeGaKi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值