版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_34672907/article/details/78327666
这段时间都在开发小程序。封装是少不了的部分。经过三轮的修改修改再修改之后,得到了下面现在一直在用的这版。如果小伙伴你只需要封装,不考虑需不需要重新登录的话可以把if(res.data.code ==5000)这段去掉。下面wxLogin也可以去掉了(强迫症,用不到的都喜欢去掉)。由于考虑到授权问,所以又加多了询问,这是我整个项目的都需要用的request函数。
module.exports = {
formatTime: formatTime,
HttpRequst: HttpRequst,
}
const baseUrl = "https://hi.xxxx.com/Ticket/";//测试环境
const dataUrl = "https://wp.xxxx.com/wechat/";//数据统计测试环境
//sessionChoose 1是带sessionID的GET方法 2是不带sessionID的GET方法, 3是带sessionID的Post方法,4是不带sessionID的Post方法
//ask是是否要进行询问授权,true为要,false为不要
//sessionChoose为1,2,3,4,所以paramSession下标为0的则为空
function HttpRequst(loading, url, sessionChoose, sessionId, params, method,ask,callBack) {
if (loading == true) {
wx.showToast({
title: '数据加载中',
icon: 'loading'
})
}
var paramSession = [{},
{ 'content-type': 'application/json', 'Cookie': 'JSESSIONID=' + sessionId },
{ 'content-type': 'application/json' },
{ 'content-type': 'application/x-www-form-urlencoded', 'Cookie': 'JSESSIONID=' + sessionId},
{ 'content-type': 'application/x-www-form-urlencoded'}]
wx.request({
url: baseUrl + url,
data: params,
dataType: "json",
header: paramSession[sessionChoose],
method: method,
success: function (res) {
if (loading == true) {
wx.hideToast();//隐藏提示框
}
if (res.data.code == 5000) {
wxLogin(loading, url, sessionChoose, sessionId, params, method,ask, callBack);
}
callBack(res.data);
},
complete: function () {
if (loading == true) {
wx.hideToast();//隐藏提示框
}
}
})
}
function wxLogin(loading, url, sessionChoose, sessionId, params, method,ask, callBack) {
wx.login({
success: function (res) {
var code = res.code;//得到code
HttpRequst(true, "ztc/product/login", false, "", { "code": code }, "GET",false, function (res) {
if (res.code == 200) {
wx.setStorageSync('sessionId', res.sessionId);
if (res.isNeedUserInfo == true) {
wx.getUserInfo({
success: function (res) {
HttpRequst(true, "ztc/product/saveUser", 3, wx.getStorageSync("sessionId"), { "encryptedData": res.encryptedData, "iv": res.iv }, "POST", false, function (res) {
HttpRequst(loading, url, sessionChoose, wx.getStorageSync("sessionId"), params, method,ask, callBack);
})
},
fail: function (res) {
console.log("我还没有授权");
if (ask == true) {
wx.showModal({
title: '提示',
confirmText: "授权",
content: '若不授权微信登陆,则无法正常使用xxx小程序的功能;点击重新授权,则重新使用;若点击不授权,后期还使用小程序,需在微信【发现】--【小程序】--删除【xxxx】,重新搜索授权登陆,方可使用',
success: function (res) {
if (res.confirm) {
console.log('用户点击确定');
wx.openSetting({
success: function (res) {
console.log(res)
if (!res.authSetting["scope.userInfo"] || !res.authSetting["scope.userLocation"]) {
//这里是授权成功之后 填写你重新获取数据的js
wx.getUserInfo({
withCredentials: false,
success: function (data) {
HttpRequst(true, "ztc/product/saveUser", 3, wx.getStorageSync("sessionId"), { "encryptedData": res.encryptedData, "iv": res.iv }, "POST", false, function (res) {
HttpRequst(loading, url, sessionChoose, wx.getStorageSync("sessionId"), params, method, ask, callBack);
})
},
fail: function () {
console.info("3授权失败返回数据");
}
});
}
}
})
}
}
})
}
}
})
} else {
HttpRequst(loading, url, sessionChoose, wx.getStorageSync("sessionId"), params, method,ask,callBack);
}
}
})
}
})
}
希望对你有帮助