Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >微信小程序wx.request重写

微信小程序wx.request重写

作者头像
似水的流年
发布于 2020-02-11 03:37:29
发布于 2020-02-11 03:37:29
1.8K0
举报
文章被收录于专栏:电光石火电光石火

https://www.jb51.net/article/164973.htm

一.

请求后台的时候,服务端对每一个请求都会验证权限,而前端也需要对服务器返回的特殊状态码统一处理,所以可以针对业务封装请求。

首先我们通过request拦截器在每个请求头里面塞入token等信息,好让后端对请求进行权限验证。并创建一个respone拦截器,当服务端返回特殊的状态码,我们统一做处理,如未登录网络错误等操作。

二.

1.首先了解小程序官方api-wx.request() ,通过示例可以看出wx.request的参数是一个对象,拥有传输地址,传输内容,响应头,成功失败回调函数等属性和方法,我们可以通过封装相应的响应头和成功失败回调函数达到相应的目的:

// 官方代码示例

wx.request({

url: 'test.php'`, //仅为示例,并非真实的接口地址`

data: {

x: ''`,`

y: ''

},

header: {

'content-type'`: 'application/json' // 默认值`

},

success (res) {

console.log(res.data)

}

fail(res){

console.log(res)

}

})

|

2.封装

封装请求头和返回的状态码(注:具体头需要添加哪些属性,返回的状态码处理,是根据与后台实际沟通所需的参数来制定的)

const app = getApp();

const appid = 'xxxx'`;`

const appSecret = 'xxxxxx'`;`

let ajaxNum = 0;

// 获取accessToken

function getAccessToken(callback) {

wx.request({

url: '/api/Token'`,`

data: {

appid: aesEncrypt(appid),`// aesEncrypt():自定义的用crypto-js.js进行aes加密的方法,这里只需要知道加密了即可,不需要关注此方法`

appSecret: aesEncrypt(appSecret),

},

success: function (res) {

if`(res.statusCode ===200 && res.data.code === 0) {`

let accesstoken = res.data.data.accesstoken;

if (`typeof (callback) === 'function' && accesstoken) {`

callback(accesstoken);

}

}

},

})

}

// 封装request请求

const myRequest = options => {

if`(options) {`

getAccessToken(`function (accesstoken){`

// header 设置Content-Type,accesstoken, usertoken, noncestr, timestamp等信息,与后台协商好

if`(options.header === undefined || options.header === null`) {

options.header = {};

}

options.header[`'Content-Type'] =` `'application/x-www-form-urlencoded; charset=UTF-8';`

// usertoken在登录后保存在缓存中,所以从缓存中取出,放在header

let usertoken = wx.getStorageSync(`'usertoken'`);

if (usertoken) {

options.header[`'usertoken'`] = usertoken;

}

// 自定义getNoncestr()设置随机字符串,getTimestamp()获取时间戳

let noncestr = getNoncestr();

let timestamp = getTimestamp();

// sign进行加密

let sign = getSign(accesstoken, appid, appSecret, noncestr, timestamp);

if (timestamp) {

options.header[`'timestamp'`] = timestamp;

}

if (noncestr) {

options.header[`'noncestr'`] = noncestr;

}

if (sign) {

options.header[`'sign'`] = sign;

}

//url

let baseUrl = config.BASE_HOST;

if (options.url.indexOf(`'http'`) != 0) {

options.url = baseUrl + options.url;

}

// method、data

if (options.method === undefined || options.method === null`) {`

options.method = 'post'`;`

}

if (options.method.toLowerCase() === 'post'`) {`

if`(options.data) {`

let dataStr = JSON.stringify(options.data);

let base64Str = base64Encrypt(dataStr);

options.data = serializeData({ param: base64Str });

}

}

//success

if (options.success && typeof`(options.success) === 'function'`) {

let successCallback = options.success;

options.success = function`(res) {`

// 判断不同的返回码 200/404

if (res.statusCode === 200) {

try {

// 接收的后台数据用自定义base64解密方法解密后转为对象

let str = base64Decrypt(res.data);

let data = JSON.parse(str);

if (parseInt(data.resultCode, 10) === -1) {`//后台商议好的状态码,-2未登录,-1-3后台出错`

console.error(`'网络超时,请稍后重试'`);

} else if (parseInt(data.resultCode, 10) === -3) {

console.error(data.msg);

} else if (parseInt(data.resultCode, 10) === -2){

console.log(`"用户未登录-ajax"`);

}

res.data = data;

//调用自定义的success

successCallback(res);

} catch (e) {

console.error(`'出错了,' + e + ',接口返回数据:' + res.data);`

}

} else if`(res.statusCode === 404) {`

console.log(`'404'`);

}

}

}

//执行微信的请求

wx.request(options);

});

}

}

module.exports = {

myRequest: myRequest

|

页面调用示范(与wx.request传参一致):

const ajax = require(`'ajax.js'`);

ajax.javaRequest({

url: '/xxx'`,`

data: {

xxxx: xxx

},

method: 'POST'`,`

success: res => {

console.log(res, '成功'`)`

}

})

|

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-12-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
微信小程序原生wx.request简单封装(自用版)
调用方法 import { get,post } from '../../request/request' // GET请求 const _res = await get('https://api.vvhan.com/api/ian') console.log(_res) // POST请求 const _res = await post('https://api.vvhan.com/api/ian') console.log(_res) request.js const request = (url
骤雨重山
2022/06/27
1.2K0
使用Promise封装小程序wx.request
现在尝试把wx.request简单的封装了一下,调用一个request方法,每次请求自动携带header头信息,这样就省事多了,包含了常见的get post put delete 四种请求方法,支持Promise方式调用。
九旬
2020/10/23
9940
【愚公系列】2022年04月 微信小程序-项目篇(公交查询)-02周边站点-获取位置和城市信息
逆地址解析:提供由经纬度到文字地址及相关位置信息的转换能力,广泛应用于物流、出行、O2O、社交等场景。服务响应速度快、稳定,支撑亿级调用。
愚公搬代码
2022/04/30
3820
微信小程序教学第二章(含视频):小程序中级实战教程之预备篇 - 封装网络请求及 mock 数据
§ 封装网络请求及 mock 数据 本文配套视频地址: https://v.qq.com/x/page/i05544fogcm.html 开始前请把 ch2-3 分支中的 code/ 目录导
iKcamp
2018/01/04
7440
微信小程序wx.request接口
wx.request是小程序客户端与服务器端交互的接口 HTTPS 请求 一个微信小程序,只能同时(同时不能大于5个)有5个网络请求
达达前端
2022/04/29
1.3K0
微信小程序wx.request接口
微信小程序 wx.requestPayment({}) 唤起微信支付
1. 登录商户平台,将商户和小程序进行关联 ---- 在 产品中心 中的 APPID账号管理 中,添加关联的小程序 appid 图片 2. 小程序调起支付API ---- 小程序调起支付API:h
很酷的站长
2023/01/16
3.2K0
微信小程序网络请求-函数封装
降低网络请求和wx.request的耦合度;使用Promise的方法获取回调结果 service.js //封装wx.request export default function request(options) { return new Promise((resolve, reject) => { wx.request({ url: options.url, //服务器接口地址 method: options.method || 'GET', //请求方法
peng_tianyu
2022/12/15
5940
PHP实现微信小程序支付完整版,可以借鉴!
Step1: 下载PHP 支付SDK(下载地址) 放到Library\Vendor下,取名Wxpay
全栈程序员站长
2022/07/08
1.2K0
微信小程序接口请求token过期用户无感应获取token重新调用接口
封装接口请求,我们的业务需要在header上加token和openid,可以根据自己的业务逻辑进行项目改变。 const baseUrl = "xxx"; const http = ({ url = '', param = {}, type = 'json', callback = '', ...other } = {}) => { wx.showLoading({ title:'请求中...', }) let timeStart = Date.now();
安德玛
2022/03/08
2K0
微信小程序授权登录
上图是微信小程序官网提供的授权登录基本流程图,这里我只从前端开发的角度来讲解一下该流程。
大发明家
2021/12/06
12.8K0
史上最详细微信小程序授权登录与后端SprIngBoot交互操作说明,附源代码,有疑惑大家可以直接留言,蟹蟹 2021.11.29 完善更新小程序代码,2022.4.27 更新
在网上找了很多很多,看了不下几十篇,说实话,有些给出了核心代码,添上一个微信官方的那张流程图就结束了,会的人一下就懂了。但是说实话,真的不适合入门学者,浪费很多时间都不一定能解决问题,将代码复制完不是少这就是少那,或者就是不齐,不然就是跑不起来,不知道看到这篇文章的你有没有遇到过这样的问题。
宁在春
2022/10/31
8K1
史上最详细微信小程序授权登录与后端SprIngBoot交互操作说明,附源代码,有疑惑大家可以直接留言,蟹蟹 2021.11.29 完善更新小程序代码,2022.4.27 更新
小程序Request的封装
更新说明:对文章排版以及内容格式做了调整。 更新时间:2022-05-04 最近做了两个小程序,业务相对比较简单,关于公益方面的,收获颇多,其中感觉在开发中明显提升开发效率以及减少代码量的就是request的封装,下面稍稍做个总结。 通用封装 在utils文件夹下新建两个文件,config.js以及request.js,代码分别如下。 <!-- config.js--> module.exports = { appid: "wxcXXXXXXXXXXXXXX349f", API_B
六个周
2022/10/28
5750
【愚公系列】2022年02月 微信小程序-Request网络请求的封装
Request网络请求在任何应用中都是必不可少的,但微信小程序的wx.request()太过单一没法满足复杂的请求,所以就有本片文章讲解如何封装小程序的请求
愚公搬代码
2022/02/22
8330
【愚公系列】2022年02月 微信小程序-Request网络请求的封装
处理微信小程序授权登录
当微信小程序项目中涉及到获取用户信息并实现用户登录时,可以通过微信官方提供的登录能力方便地获取微信的用户身份标识,快速建立小程序内的用户体系。官方文档只是提供如何去调用授权登录,如果直接原封不动的照搬文档来进行代码编写,这样势必会造成代码的维护性差,所以本篇着重介绍如果更优雅的处理微信小程序的授权登录。
ruochen
2021/11/26
8.3K0
java小程序微信支付与提现
去微信支付开发文档下载官方demo https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=11_1 得到以下几个文件 编写微信常量文件用来存
jaychou
2022/12/26
2K0
C# 实现微信自定义分享
在实际的应用中,我们可能不是简单的将该网页的链接直接分享出去,而是生成符合实际需要的URL,微信称其为自定义分享。意思即,在用户点击“转发给朋友”按钮之前,进行URL等内容的更新 ,经过调整后,再把链接发送给要分享的朋友。微信给出的关键方法是:updateAppMessageShareData。
初九之潜龙勿用
2024/06/20
2450
C# 实现微信自定义分享
微信小程序 网络请求封装
post请求和get请求不一样的地方在于header中的content-type参数和method参数
yechaoa
2022/06/10
6510
微信小程序 wx.request 的封装
自学转行到前端也已近两年,也算是简书和掘金的忠实粉丝,但是以前一直惜字如金(实在是胆子小,水平又低),现在我决定视金钱如粪土(就只是脸皮厚了,水平就那样),好了废话不多说,切入主题,最近自己尝试了一下小程序开发,坑么总是有的,但是我觉得还是request这部分实在是不好看,所以你懂得,我用Promise 对请求做了个简单封装。本文章所述方法主要针对第三方登录
极乐君
2018/02/03
2.3K0
微信小程序开发 – 用户授权登陆「建议收藏」
本篇将帮助读者实现基于 微信开发者工具 & C#环境 下的用户在小程序上的授权登陆。
全栈程序员站长
2022/07/01
1.6K0
微信小程序开发 – 用户授权登陆「建议收藏」
mpvue小程序架构搭建详细介绍
mpvue小程序框架搭建很容易,官网提供vue init mpvue/mpvue-quickstart my-project, 很迅速的创建项目,但是想要结合业务等,还是要废一番功夫,今天来学学wx.request的封装,mpvue的重构,如何搭建好用的mpvue小程序架构吧
Javanx
2019/09/04
8740
mpvue小程序架构搭建详细介绍
相关推荐
微信小程序原生wx.request简单封装(自用版)
更多 >
LV.2
这个人很懒,什么都没有留下~
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档