小程序request封装的详细流程
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,这篇文章主要讲解了"小程序request封装的详细流程",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"小程序request封装的详细流程"吧!背景之前小
千家信息网最后更新 2025年02月01日小程序request封装的详细流程
这篇文章主要讲解了"小程序request封装的详细流程",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"小程序request封装的详细流程"吧!
背景
之前小程序代码混乱,所以新项目一开始就准备弄个微信小程序的 request 的封装
流程
先来说说整个流程:
1.appjs 里面已进入就去获取用户信息,如果没有登录则默认登录,这里不做错误处理
2.用户必须同意授权才能进行操作,如果不同意授权则会一直跳转到授权页面
undefined
app.js
onLaunch 里面获取用户信息
appSelf = this; // 应用程序第一次进入,获取用户信息,不做任何错误处理 userInfo().then( (res)=>{ console.log(res);// 打印结果 if (!res.code) { appSelf.globalData.userInfo = res } }).catch( (errMsg)=>{ console.log(errMsg);// 错误提示信息 });
httpUtils.js
request 的封装
const request = function (path, method, data, header) { let user_id = ""; let token = ""; try { user_id = wx.getStorageSync(USER_ID_KEY); token = wx.getStorageSync(TOKEN_KEY); } catch (e) {} header = header || {}; let cookie = []; cookie.push("USERID=" + user_id); cookie.push("TOKEN=" + token); cookie.push("device=" + 1); cookie.push("app_name=" + 1); cookie.push("app_version=" + ENV_VERSION); cookie.push("channel=" + 1); header.cookie = cookie.join("; "); return new Promise((resolve, reject) => { wx.request({//后台请求 url: API_BASE_URL + path, header: header, method: method, data: data, success: function (res) { if (res.statusCode !== 200) { reject(res.data) } else { if (res.data.code === 20006) { login().then( (res)=>{ resolve(res) }).catch( (errMsg)=>{ reject(errMsg); }) } resolve(res.data) } }, fail: function (res) { reject("not data"); } }); });}
login
const login = function () { try { wx.removeStorageSync(USER_ID_KEY) wx.removeStorageSync(TOKEN_KEY) } catch (e) {} return new Promise((resolve, reject) => { wx.login({ success: res => { let code = res.code; // 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框 wx.getUserInfo({ withCredentials: true, success: res => { let userInfo = res.userInfo; let name = userInfo.nickName; let avatar = userInfo.avatarUrl; let sex = userInfo.gender; let data = { code: code, encryptedData: res.encryptedData, iv: res.iv, name: name, avatar: avatar, sex: sex, from: FROM, }; request("/api/user/login/byWeChatApplet", "POST", data).then( (res)=>{ if (!res.code) { try { wx.setStorageSync(USER_ID_KEY, res.user_id); wx.setStorageSync(TOKEN_KEY, res.token) } catch (e) { reject(JSON.stringify(e)); } } resolve(res) }).catch( (errMsg)=>{ reject(errMsg) }); }, fail: function (res) { console.log(res); if (res.errMsg && res.errMsg.startsWith("getUserInfo:fail") && res.errMsg.search("unauthorized") != -1) { // 跳转授权页面 wx.navigateTo({ url: '/pages/auth/auth' }) return; } wx.getSetting({ success: (res) => { if (!res.authSetting["scope.userInfo"]) { // 跳转授权页面 wx.navigateTo({ url: '/pages/auth/auth' }) } } }); } }) } }) });};
auth.js
授权页面 js
Page({ data: { }, onLoad: function () { self = this; }, auth: function (e) { console.log(app.globalData.userInfo); if (e.detail.userInfo) { login().then( (res)=>{ console.log(res);// 打印结果 if (res.code) { // 接口错误 return } // 跳转回上一个页面 wx.navigateBack() }).catch( (errMsg)=>{ console.log(errMsg);// 错误提示信息 }); } },});
感谢各位的阅读,以上就是"小程序request封装的详细流程"的内容了,经过本文的学习后,相信大家对小程序request封装的详细流程这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
程序
流程
封装
信息
错误
页面
用户
学习
内容
结果
处理
提示
登录
混乱
代码
后台
头像
就是
应用程序
思路
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
手机连云服务器软件
redis数据库访问接口
河南谷雨网络技术怎么样
java往数据库插入数据
MySQL跨机器查询数据库
贵州嘉淘惠网络技术有限公司
工业网络技术插本能插什么专业
达梦数据库dminit
本票密押服务器
外游加速器服务器地址
陌陌软件开发成本
c 简易数据库
方舟服务器可以卡bug吗
通信行业软件开发
ei数据库检索技巧
强的眼镜行业软件开发
软件开发特有名的人
深圳市华思特网络技术
网络安全主题设计说明
php数据库字段
书馆网页万方数据库
长宁区项目软件开发定制大概费用
数据库怎么显示修改时间
瑞庭网络技术厦门
驰普网络技术公司
网络安全防骗意识
法院网络安全工作自查报告
百度数据库变化表格更新代码
一物一码软件开发
广东联通软件开发薪资