解决繁琐的小程序会话管理,一款自带登录态管理的网络请求组件。

网友投稿 767 2022-10-18

解决繁琐的小程序会话管理,一款自带登录态管理的网络请求组件。

解决繁琐的小程序会话管理,一款自带登录态管理的网络请求组件。

v1.2.15

解决繁琐的小程序会话管理,一款自带登录态管理的网络请求组件。

目标

让业务逻辑更专注,不用再关注底层登录态问题。小程序对比以往的H5,登录态管理逻辑要复杂很多。通过weRequest这个组件,希望能帮助开发者把更多精力放在业务逻辑上,而登录态管理问题只需通过一次简单配置,以后就不用再花精力管理了。

如何安装

a) 通过npm安装

npm install --save we-request

b) 或直接-build/weRequest.min.js放到小程序包内

怎么使用

1) 引入weRequest组件

1.a)ES6模式

import weRequest from 'we-request';// 若-文件到本地,则直接引入对应文件,具体路径自己根据情况修改// import weRequest from '../lib/weRequest.min'

1.b) commonJs 模式

const weRequest= require('we-request');// 若-文件到本地,则直接引入对应文件,具体路径自己根据情况修改// const weRequest = require('../lib/weRequest.min');

2) 初始化组件配置

// 初始化配置weRequest.init({ // 关于配置内容,将在后文详述 // 此处暂时省略...})

3) 就像使用wx.request那样去使用它

// 发起请求weRequest.request({ url: 'order/detail', data: { id: '107B7615E04AE64CFC10' }, success: function (data) { // 省略... }})// 同时也支持Promise形式使用weRequest.request({ url: 'order/detail', data: { id: '107B7615E04AE64CFC10' }}).then((data)=>{ // 省略...})

使用贴士

正常情况下组件只需要init一次即可,因此初始化可以封装在一个文件中:

// 举例: 以下代码封装在 util/weRequest.jsimport weRequest from 'we-request';weRequest.init({ // ...});export default weRequest;

后续业务逻辑直接引用封装好的文件即可使用:

import weRequest from 'util/weRequest';weRequest.request({ // ...})

为什么需要它

上图是小程序官方文档中的登录时序图。此图涵盖了前后端,详细讲解了包括登录态的生成,维护,传输等各方面的问题。

hasChecked: 用一状态标识本生命周期内是否执行过wx.checkSession,判断该标识,若否,开始执行wx.checkSession,若是,进入下一步wx.checkSession(): 调用接口判断登录态是否过期,若是,重新登录;若否,进入下一步

wx.checkSession()是小程序提供的检测登录态是否过期的接口,生命周期内只需调用一次即可。用户越久未使用小程序,用户登录态越有可能失效。反之如果用户一直在使用小程序,则用户登录态一直保持有效。具体时效逻辑由微信维护,对开发者透明

wx.getStorage(session): 尝试获取本地的session。如果之前曾经登录过,则能获取到;否则,本地无sessionwx.login(): 小程序提供的接口,用于获取code(code有效期为5分钟)wx.request(code): 将code通过后台提供的接口,换取sessionwx.setStorage(session): 将后台接口返回的session存入到localStorage,以备后续使用wx.request(session): 真正发起业务请求,请求中带上sessionparse(data): 对后台返回的数据进行预解析,若发现登录态失效,则重新执行登录;若成功,则真正获取到业务数据

只要遵循上图的流程,我们就无需在业务逻辑中关注登录态的问题了,相当于把登录态的管理问题耦合到了发起网络请求当中,本组件则完成了上述流程的封装,让开发者不用再关心以上逻辑,把精力放回在业务的开发上。

演示DEMO

自动带上登录态参数

没有登录态时,自动登录

登录态过期时,自动重新登录

文档

.init(OBJECT)

对组件进行初始化配置,使用组件发起请求前必须进行至少一次的配置

OBJECT参数说明

codeToSession参数说明

参数名类型必填默认值说明
urlStringCGI的url
methodStringGET调用改CGI的方法
codeNameStringcodeCGI中传参时,存放code的名称
dataObject登录接口需要的其他参数
successFunction接口返回成功的函数;需要返回session的值

reportCGI返回参数说明

参数名类型说明
nameString调用的接口名字,可在request接口的report字段配置
startTimeInt发起请求时的时间戳
endTimeInt请求返回时的时间戳
requestFunction请求方法,可用于上报

示例代码

weRequest.init({ // [可选] 存在localStorage的session名称,且CGI请求的data中会自动带上以此为名称的session值;可不配置,默认为session sessionName: "session", // [可选] 请求URL的固定前缀;可不配置,默认为空 urlPerfix: "https://example.com/", // [必填] 触发重新登录的条件,res为CGI返回的数据 loginTrigger: function (res) { // 此处例子:当返回数据中的字段errcode等于-1,会自动触发重新登录 return res.errcode == -1; }, // [必填] 用code换取session的CGI配置 codeToSession: { // [必填] CGI的URL url: 'user/login', // [可选] 调用改CGI的方法;可不配置,默认为GET method: 'GET', // [可选] CGI中传参时,存放code的名称,此处例子名称就是code;可不配置,默认值为code codeName: 'code', // [可选] 登录接口需要的其他参数;可不配置,默认为{} data: {}, // [必填] CGI中返回的session值 success: function (res) { // 此处例子:CGI返回数据中的字段session即为session值 return res.session; } }, // [可选] 登录重试次数,当连续请求登录接口返回失败次数超过这个次数,将不再重试登录;可不配置,默认为重试3次 reLoginLimit: 2, // [必填] 触发请求成功的条件 successTrigger: function (res) { // 此处例子:当返回数据中的字段errcode等于0时,代表请求成功,其他情况都认为业务逻辑失败 return res.errcode == 0; }, // [可选] 成功之后返回数据;可不配置 successData: function (res) { // 此处例子:返回数据中的字段data为业务接受到的数据 return res.data; }, // [可选] 当CGI返回错误时,弹框提示的标题文字 errorTitle: function(res) { // 此处例子:当返回数据中的字段errcode等于0x10040730时,错误弹框的标题是“温馨提示”,其他情况下则是“操作失败” return res.errcode == 0x10040730 ? '温馨提示' : '操作失败' }, // [可选] 当CGI返回错误时,弹框提示的内容文字 errorContent: function(res) { // 此处例子:返回数据中的字段msg为错误弹框的提示内容文字 return res.msg ? res.msg : '服务可能存在异常,请稍后重试' }, // [可选] 当出现CGI错误时,统一的回调函数,这里可以做统一的错误上报等处理 errorCallback: function(obj, res) { // do some report }, // [可选] 当出现错误时,弹框是否显示重试按钮,默认为false errorRetryBtn: true, // [可选] 是否需要调用checkSession,验证小程序的登录态过期,可不配置,默认为false doNotCheckSession: true, // [可选] 上报耗时的函数,name为上报名称,startTime为接口调用开始时的时间戳,endTime为接口返回时的时间戳 reportCGI: function(name, startTime, endTime, request) { //wx.reportAnalytics(name, { // time: endTime - startTime //}); //request({ // url: 'reportCGI', // data: { // name: name, // cost: endTime - startTime // }, // fail: function() { // // } //}) console.log(name + ":" + (endTime - startTime)); }, // [可选] 提供接口的mock,若不需使用,请设置为false。url为调用weRequest.request()时的url。mock数据的格式与正式接口提供的数据格式一致。 mockJson: { url1: require("../../mock1.json"), url2: require("../../mock2.json"), url3: require("../../mock3.json") }, // [可选] 所有请求都会自动带上globalData里的参数 globalData: function() { return { version: getApp().version } }, // [可选] session本地缓存时间(单位为ms),可不配置,默认不设置本地缓存时间 sessionExpireTime: 24 * 60 * 60 * 1000, // [可选] session本地缓存时间存在Storage中的名字,可不配置,默认为 sessionExpireKey sessionExpireKey: "sessionExpireKey"})

.request(OBJECT)

[return Promise] 带上登录态发起一个请求,参数大部分与wx.request一致

OBJECT参数说明

参数名类型必填默认值说明是否与wx.request不一致
urlString开发者服务器接口地址,若在init()时有配置urlPerfix,则这里会自动拼接前缀
dataObject/String请求的参数
headerObject设置请求的 header,header 中不能设置 Referer。
methodStringGET(需大写)有效值:OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
dataTypeStringjson如果设为json,会尝试对返回的数据做一次 JSON.parse
beforeSendFunction发起请求前执行的函数
successFunction收到开发者服务成功返回,且执行successTrigger成功后的回调函数,参数为successData返回的参数
failFunction接口调用失败,或执行successTrigger失败后的回调函数,若这里有配置,则不再默认弹窗报错
completeFunction接口调用结束的回调函数(调用成功、失败都会执行)
showLoadingBoolean/Stringfalse请求过程页面是否展示全屏的loading,当值为字符串时,将展示相关文案的loading
reportString接口请求成功后将自动执行init()中配置的reportCGI函数,其中的name字段值为这里配置的值
cacheBoolean接口是否启用缓存机制,若为true,将以url为key将结果存储在storage中,下次带cache的请求优先返回缓存内容,success回调中第二个参数对象的isCache值将标识内容是否为缓存
noCacheFlashBoolean当启用缓存时,决定除了返回缓存内容外,是否还返回接口实时内容,以防止页面多次渲染的抖动
catchErrorBooleanfalse当使用Promise模式时,开发者是否需要捕获错误(默认不捕获,统一自动处理错误)

示例代码

weRequest.request({ url: 'order/detail', showLoading: true, report: 'detail', data: { id: '123' }, success: function (data, ext) { console.log(data, ext.isCache); }, fail: function(res) { }})

.uploadFile(Object)

[return Promise] 带上登录态,将本地资源上传到开发者服务器,客户端发起一个 HTTPS POST 请求,其中 content-type 为 multipart/form-data,参数大部分与wx.uploadFile一致

OBJECT参数说明

参数名类型必填默认值说明是否与wx.uploadFile不一致
urlString开发者服务器接口地址,若在init()时有配置urlPerfix,则这里会自动拼接前缀
filePathString要上传文件资源的路径
nameString文件对应的 key , 开发者在服务器端通过这个 key 可以获取到文件二进制内容
headerObject设置请求的 header,header 中不能设置 Referer。
formDataObjectHTTP 请求中其他额外的 form data
beforeSendFunction发起请求前执行的函数
successFunction收到开发者服务成功返回,且执行successTrigger成功后的回调函数,参数为successData返回的参数
failFunction接口调用失败,或执行successTrigger失败后的回调函数,若这里有配置,则不再默认弹窗报错
completeFunction接口调用结束的回调函数(调用成功、失败都会执行)
showLoadingBoolean/Stringfalse请求过程页面是否展示全屏的loading,当值为字符串时,将展示相关文案的loading
reportString接口请求成功后将自动执行init()中配置的reportCGI函数,其中的name字段值为这里配置的值
catchErrorBooleanfalse当使用Promise模式时,开发者是否需要捕获错误(默认不捕获,统一自动处理错误)

示例代码

wx.chooseImage({ count: 1, success: function (res) { weRequest.uploadFile({ url: 'upload/img', filePath: res.tempFilePaths[0], name: 'pic', showLoading: "提交中", success(data){ console.log(data.imgPath); } }) }})

.getSession()

[return String] 获取本地缓存中用户票据的值

.getConfig()

[return Object] 获取weRequest的配置。返回的Object内容如下:

参数名类型说明
urlPerfixString or Function在组件初始化时传入的请求URL的固定前缀
sessionExpireTimeInt在组件初始化时传入的用户登陆态设置本地缓存时间
sessionExpireKeyString在组件初始化时传入的用户登陆态本地缓存时间Storage的key
sessionExpireInt用户登陆态本地缓存过期的时间戳

.login()

[不建议使用] 在不发起业务请求的情况下,单独执行登录逻辑

.setSession(String)

[不建议使用] 设置用户票据的值

.version

获取 weRequest 版本号

FAQ

我希望在请求时候,页面能出现最简单的loading状态,该怎么办?

只需要在请求的时候,加上参数showLoading: true即可,如:

weRequest.request({ url: 'order/detail', showLoading: true, data: { id: '123' }, success: function (data) { console.log(data); }})

当然,如果你希望使用个性化的loading样式,你可以直接使用beforeSend参数来进行自定义展示个性化的loading,并且在complete的时候将它隐藏。

某些请求在返回错误时,我不希望触发通用的错误提示框,而想用特别的逻辑去处理,该怎么办?

只需要在请求的时候,加上参数fail: function(){ ... }即可,如:

weRequest.request({ url: 'order/detail', slience: true, data: { id: '123' }, success: function (data) { console.log(data); }, fail: function(res) { console.log(res); }})

此时,如果接口返回错误码,将触发这里定义的fail函数,且默认错误弹框将不会出现。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:DockProgress:在程序坞(Dock)应用图标区域显示进程条。
下一篇:注意:雪花算法并不是ID的唯一选择!
相关文章

 发表评论

暂时没有评论,来抢沙发吧~