小程序 + node koa2 session存储验证码碰到最大的坑,(喜极而泣 /狗头)

问题:session存验证码。本地拿postman测试了半天,都没有问题。   但到了小程序,服务端再获取(ctx.session.verifyCode)就一直提示不存在。undefined

 

小程序会话机制:微信小程序不能保存Cookie,导致每次wx.request到服务端都会创建一个新的会话,从而当前会话不再是之前存验证码的那个会话,自然也就取不到session值了。

 

node - session:用cookie传递,在response-header加上set-cookie

 

客观,不要着急。拿图看一下,

第一张图片是getVerifyImg 接口的response-header,大家可以看到的是有了set-cookie

 

 

 

 接下来是验证的接口,上图片

大家可以看到,request-header中没有了cookie

 

 

 

解决办法是: 小程序端获取到session  cookie的时候要使用storage  缓存起来,放在请求头上,

但是还没完,注意细节决定你得接口

node session中  GMT后面是用的  ; 拼接的

但是小程序中 是用    , 拼接的

 

 

 所以再存储的时候,要转一下,本人正则比较拉,只会repalce ,莫嘲笑

console.log( res.header['Set-Cookie'])
wx.setStorageSync('cookie', res.header['Set-Cookie'].replace('GMT,', 'GMT;'))

然后放在request 中的header中就可以了

 

posted @   时光凉忆  阅读(182)  评论(0编辑  收藏  举报
编辑推荐:
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
阅读排行:
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
· 上周热点回顾(2.17-2.23)
点击右上角即可分享
微信分享提示