You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

180 lines
5.0 KiB

import request from "./request";
// 上传文件和个人头像需要单独改
// 全局配置的请求域名
let baseUrl = "https://www.feifanhitech.com";
// 职站appid: wx77a8a2a23138998b
// 大庆appid: wx094657cb56f4dc70
// let baseUrl = "https://test.feifanhitech.com";
//可以new多个request来支持多个域名请求
let $http = new request({
//接口请求地址
baseUrl: baseUrl,
//服务器本地上传文件地址
fileUrl: baseUrl,
// 服务器上传图片默认url
defaultUploadUrl: "api/common/v1/upload_image",
//设置请求头(如果使用报错跨域问题,可能是content-type请求类型和后台那边设置的不一致)
header: {
'content-type': 'application/json;charset=UTF-8'
},
// 请求超时时间(默认6000)
timeout: 6000,
// 默认配置(可不写)
config: {
// 是否自动提示错误
isPrompt: true,
// 是否显示加载动画
load: true,
// 是否使用数据工厂
isFactory: true
}
});
// 添加获取七牛云token的方法
// $http.getQnToken = function(callback){
// //该地址需要开发者自行配置(每个后台的接口风格都不一样)
// $http.get("api/kemean/aid/qn_upload").then(data => {
// /*
// *接口返回参数:
// *visitPrefix:访问文件的域名
// *token:七牛云上传token
// *folderPath:上传的文件夹
// *region: 地区 默认为:SCN
// */
// callback({
// visitPrefix: data.visitPrefix,
// token: data.token,
// folderPath: data.folderPath,
// region: "SCN"
// });
// });
// }
//当前接口请求数
let requestNum = 0;
//请求开始拦截器
$http.requestStart = function(options) {
if (options.load) {
if (requestNum <= 0) {
//打开加载动画
uni.showLoading({
title: '加载中',
mask: true
});
}
requestNum += 1;
}
// 图片上传大小限制
if (options.method == "FILE" && options.maxSize) {
// 文件最大字节: options.maxSize 可以在调用方法的时候加入参数
const maxSize = options.maxSize;
for (let item of options.files) {
if (item.size > maxSize) {
setTimeout(() => {
uni.showToast({
title: "图片过大,请重新上传",
icon: "none"
});
}, 500);
return false;
}
}
}
//请求前加入token
options.header['token'] = uni.getStorageSync('token')
return options; // return false 表示请求拦截,不会继续请求
}
//请求结束
$http.requestEnd = function(options) {
//判断当前接口是否需要加载动画
if (options.load) {
requestNum = requestNum - 1;
if (requestNum <= 0) {
uni.hideLoading();
}
}
}
//登录弹窗次数
let loginPopupNum = 0;
//所有接口数据处理(可在接口里设置不调用此方法)
//此方法需要开发者根据各自的接口返回类型修改,以下只是模板
$http.dataFactory = async function(res) {
if (res.response.statusCode && res.response.statusCode == 200) {
let httpData = res.response.data;
if (typeof (httpData) == "string") {
httpData = JSON.parse(httpData);
}
/*********以下只是模板(及共参考),需要开发者根据各自的接口返回类型修改*********/
// console.log(getCurrentPages()[0].$page.fullPath,'当前路由查看');
//判断数据是否请求成功
if (httpData.code == 10000) {
// 返回正确的结果(then接受数据)
return Promise.resolve(httpData);
} else if (httpData.code == "401" || httpData.code == 401) {
// 判断登录失效,进行查询
uni.removeStorageSync('token')
uni.removeStorageSync('account')
uni.removeStorageSync('headPortaritUrl')
// console.log('在判断401,115行处抛出错误')
// 判断当前是否在登录页触发的登录过期
if(getCurrentPages()[0].$page.fullPath!=='/pages/user/user') {
uni.showModal({
title: '登录过期',
content: '请重新进行登录',
confirmText: "去登录",
cancelText: "取消",
success: function (res) {
if (res.confirm) {
uni.switchTab({
url: "/pages/user/user"
})
}
}
});
}
// 返回错误的结果(catch接受数据)
return Promise.reject({
statusCode: 0,
errMsg: "【request】" + (httpData.message)
});
} else { //其他错误提示
if (res.isPrompt) {
uni.showToast({
title: httpData.message,
icon: "none",
duration: 3000
});
}
// console.log('145行抛出错误')
// 返回错误的结果(catch接受数据)
return Promise.reject({
statusCode: 0,
errMsg: "【request】" + (httpData.message),
data:res.response.data
});
}
} else {
// console.log('154行抛出',res)
// 返回错误的结果(catch接受数据)
return Promise.reject({
statusCode: res.response.statusCode,
errMsg: "【request】数据工厂验证不通过",
data:res.response.data,
});
}
};
// 错误回调
$http.requestError = function (e) {
// e.statusCode === 0 是参数效验错误抛出的
if (e.statusCode === 0) {
throw e;
} else {
uni.showToast({
title: e.data.message,
icon: "none"
});
}
}
export default $http;