const baseUrl="http://localhost:3000"
function showToast(msg, icon = 'error') {
uni.showToast({
title: msg,
icon,
});
}
// 添加拦截器
const httpInterceptor = {
// 拦截前触发
invoke(options) {
// 1. 非 http 开头需拼接地址
if (!options.url.startsWith('http')) {
options.url = baseUrl + options.url;
console.log("url--",options)
}
// 2. 请求超时, 默认 60s
options.timeout = 60 * 1000;
options.header={...options}
// 3. 初始化header
if (isBlank(options.header)) {
options.header = {};
}
// 4. 添加 token 请求头标识
const token =uni.getStorageSync("token")
// 获取本地存储的token
if (token) {
options.header.Authorization = `Bearer ${token}`;
}else{
uni.redirectTo({
url:"/pages/login/login"
})
}
},
};
uni.addInterceptor('request', httpInterceptor);
export const http=(options)=> {
return new Promise((resolve,reject)=>{
if(options.loading) uni.showLoading({title: '加载中'});
uni.request({
...options,
success(res){
// resolve(res)
const rawData = res.data;
if (res.statusCode >= 200 && res.statusCode < 300) {
// 判断跟后端约定好的成功标识
if (rawData.code !== 0) {
showToast(rawData.message, 'none');
}
resolve(rawData);
} else if (res.statusCode === 401) {
// token 失效处理
reject(res);
} else {
switch (res.statusCode) {
case 404:
showToast('请求资源不存在');
break;
case 500:
showToast('服务器错误');
break;
case 502:
showToast('找不到对应服务器');
break;
default:
showToast(rawData?.message || '请求异常');
break;
}
reject(res);
}
},
complete(){
if(options.loading) uni.hideLoading();
},
fail(err){
reject(err)
}
})
})
}
二:在api.jsw文件中
import {http} from "../utils/http"
import "../utils/http"
export const getList=()=>{
return http({
method:"GET",
url:"/api/list",
loading:true
})
}
uniapp全局拦截封装(一)
sleeppingfrog2023-12-12 11:32
相关推荐
于先生吖13 小时前
UniApp搭配Java后端实现到店预约上门指派,订单状态流转与结算开发教程岳哥i16 小时前
uniapp打包原生App流程及兼容性适配niech_cn17 小时前
uniapp开发App(iOS、Android、鸿蒙Next)之配置pages.json 页面路由(三)郑州光合科技余经理18 小时前
海外版外卖系统源码:支付/地图/多语言核心代码实现游戏开发爱好者819 小时前
Linux 自动上传 App Store Connect:把 IPA 上传流程接进CI工作流暗冰ཏོ19 小时前
《uni-app 跨端开发完整指南:从基础入门到 H5、小程序、App 发布上线》梦梦代码精19 小时前
TP8+Vue3+UniApp:LikeShop架构受青睐!暗冰ཏོ20 小时前
2026 App 开发完整指南:Android、iOS、跨平台开发与安卓应用上线全流程Geek_Vison2 天前
技术实践:保险健康APP引入第三方小程序实战,如何构建一个安全可控的沙箱环境~2501_915918412 天前
Python如何抓取HTTPS请求包的完整教程与代码示例