解决微信小程序报错Illegal Buffer

解密手机原理:微信小程序是通过wx.login生成code,然后传给后端,后端在通过code拿到用户信息,再通过sessionKey和用户信息来解密得出手机号的

报错原因:用户退出登录后登录,因为wx.login一直在 刷新code,在小程序给的nodejs解密中,报错原因是因为该解密的sessionKey没过期而不认新的sessionKey,所以会报Illegal Buffer

解决办法:把用户信息存数据库,然后给openid加密,充当登录态token,再把token返回小程序,小程序将其储存于 本地缓存中,后面退出登录 后拿本地缓存中的登录态 来获取用户数据,从而绕过再一次解密手机号。(ps:第一次登录解密是没问题的,因为没有旧的sessionKey干扰)

 

PS:为什么要存数据库?而不存redis这些?因为redis会定时被清除,而小程序希望一直是登录的,除非自动退出,所以当退出 后在登录,这时redis已经被自动清除,所以拿不到用户信息,所以改存mysql。

PS:为什么用openid来加密,而不是用自动生成一个加密码?因为经过我们测试,发现储存在本地缓存的token有时会被自动清除??一开始我们也是问号,然后通过如果返回为空,在 重新调用wx.login,再一次重新登录来 获取用户openid,然后再跟数据库对比,拿出用户数据,绕过这种情况

PS:wx.login不要每次都调用,用wx.checksession来判断是否过期,过期重新调用

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这个错误通常是由于在使用 `isset()` 或 `empty()` 函数时传入了一个非数组或对象类型的变量作为参数。 例如: ``` $x = "abc"; if (isset($x[0])) { // code here } ``` 在上面的代码中,由于 `$x` 是字符串类型,所以访问 `$x[0]` 时会抛出 "Illegal offset type" 错误。 解决方法是确保传入 `isset()` 或 `empty()` 函数的参数是数组或对象类型,或者在使用数组或对象的方式访问变量之前先进行类型检查。 例如: ``` if (is_array($x) && isset($x[0])) { // code here } ``` 或者: ``` if (is_object($x) && isset($x->property)) { // code here } ``` ### 回答2: 该问题是由于在PHP7.1中使用了非法的偏移类型造成的。在PHP7.1之前的版本中,isset()或empty()函数可以接受任何类型的偏移量,包括整数、字符串、浮点数等。但是在PHP7.1中,这两个函数只能接受整数或字符串类型的偏移量。 解决这个问题的方法有两种。第一种方法是将非整数或非字符串类型的偏移量转换为整数或字符串类型。例如,可以使用intval()函数将浮点数转换为整数,使用strval()函数将其他类型的偏移量转换为字符串。然后再将转换后的偏移量传递给isset()或empty()函数进行操作。 第二种方法是使用数组的key_exists()函数来进行判断,而不是使用isset()或empty()函数。key_exists()函数不会对偏移量进行类型检查,因此可以接受任何类型的偏移量。但是需要注意的是,key_exists()函数只能用于数组,并且需要将数组和偏移量作为参数传递给该函数。 综上所述,要解决在PHP7.1中运行的小程序出现的"Illegal offset type in isset or empty"报错,可以将非整数或非字符串类型的偏移量转换为整数或字符串类型,或者使用数组的key_exists()函数进行判断。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值