微信小程序实现Session功能及无法获取session问题的解决方法
(编辑:jimmy 日期: 2025/1/16 浏览:3 次 )
因为小程序原生不支持Cookie,因此也不支持Session。
网上找到的的一些方法有缺陷,而且很多累赘,估计没有实际测试过,在此直接给出实测可用的代码。
大概思路就是借助小程序本地储存+网络请求的header可读可写来实现类似浏览器的cookies保存session功能。
直接上代码
function NetRequest({url, data, success, fail, complete, method = "POST", header = { 'Content-type': 'application/x-www-form-urlencoded' }}) { let session_id = wx.getStorageSync('PHPSESSID');//本地取存储的sessionID if (session_id != "" && session_id != null) { //本地session存在,则放到header里 header.Cookie = session_id; } wx.request({ url: url, method: method, data: data, header: header, success: res => { //发现response有Set-Cookie,说明本地的PHPSESSID需要更新或不存在: if(res.header["Set-Cookie"]){ wx.setStorageSync('PHPSESSID', res.header["Set-Cookie"]); } res['statusCode'] === 200 "color: #ff0000">PS:下面看下彻底解决小程序无法获取SESSION问题最近在开发小程序,发现小程序是通过微信服务器触发我们服务器,所以每次请求获取到的session_id都不同,导致小程序中无法获取session,这样我就想如果session_id不发生变化,那么session是否可以使用呢???
查看了一下小程序的开发文档(wx.request);
发起网络请求中有一个header参数,
我们可以通过header传递一个固定参数到后台,
作为session_id,这样sesion_id不发生变化,
微信小程序中就可以使用或触发session了。一、首先找到第一次发起网络请求的地址,将服务器返回set-cookie当全局变量存储起来
wx.request({ ......//此处省略 success: function(res) { console.log(res.header); wx.removeStorageSync('sessionid') //必须先清除,否则res.header['Set-Cookie']会报错 //set-cookie:PHPSESSID=ic4vj84aaavqgb800k82etisu0; path=/; domain=.zhix.net // 登录成功,获取第一次的sessionid,存储起来 // 注意:Set-Cookie(开发者工具中调试全部小写)(远程调试和线上首字母大写) wx.setStorageSync("sessionid", res.header["Set-Cookie"]); } })二、请求时带上将sessionid放入request的header头中传到服务器,服务器端可直接在cookie中获取
wx.request({ ...... header: { 'content-type': 'application/json', // 默认值 'cookie': wx.getStorageSync("sessionid") //读取sessionid,当作cookie传入后台将PHPSESSID做session_id使用 }, success: function(res) { console.log(res) } })三、后台获取cookie中的PHPSESSID,将PHPSESSID当作session_id使用
<"color: #ff0000">总结以上所述是小编给大家介绍的微信小程序实现Session功能及无法获取session问题的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
下一篇:webpack-mvc 传统多页面组件化开发详解
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。