- button=bindgetuserinfo的点击与wx.login先后顺序
之前通过 `wx.getUserInfo()` 获取用户信息时,它有个前提条件要求先 `wx.login()` 而且未过期。现在换成通过按钮触发的形式后,是在哪一个阶段获取授权code呢?是在点击按钮之前就要获取到code?还是在bindgetuserinfo的回调函数内部获取code? 在bindgetuserinfo的回调函数内部获取的code,会不会是无效的? 以为部分JS源码(mpvue): [代码] [代码][代码]export [代码][代码]default[代码] [代码]{[代码] [代码] [代码][代码]methods: {[代码] [代码] [代码][代码]async onGetUserInfo (res) { [代码][代码]// bindgetuserinfo的回调函数[代码] [代码] [代码][代码]const that = [代码][代码]this[代码] [代码] [代码][代码]const { userInfo, errMsg, encryptedData, iv } = res.target[代码] [代码] [代码][代码]if[代码] [代码](errMsg === [代码][代码]'getUserInfo:ok'[代码][代码]) {[代码] [代码] [代码][代码]wx.login({[代码] [代码] [代码][代码]success (loginRet) {[代码] [代码] [代码][代码]if[代码] [代码](loginRet[[代码][代码]'code'[代码][代码]]) {[代码] [代码] [代码][代码]that.loginAfter({[代码] [代码] [代码][代码]userInfo,[代码] [代码] [代码][代码]encryptedData,[代码] [代码] [代码][代码]iv,[代码] [代码] [代码][代码]code: loginRet[[代码][代码]'code'[代码][代码]][代码] [代码] [代码][代码]})[代码] [代码] [代码][代码]}[代码] [代码] [代码][代码]},[代码] [代码] [代码][代码]complete (loginRet) {[代码] [代码] [代码][代码]if[代码] [代码](!loginRet[[代码][代码]'code'[代码][代码]]) {[代码] [代码] [代码][代码]wx.showModal({ title: [代码][代码]'授权失败'[代码] [代码]})[代码] [代码] [代码][代码]}[代码] [代码] [代码][代码]}[代码] [代码] [代码][代码]})[代码] [代码] [代码][代码]}[代码] [代码] [代码][代码]},[代码] [代码] [代码][代码]loginAfter ({ userInfo, encryptedData, iv, code }) {[代码] [代码] [代码][代码]// 服务端通过 code 获取 session_key 再解密 decrypted 获取 openid unionid[代码] [代码] [代码][代码]}[代码] [代码] [代码][代码]}[代码] [代码] [代码][代码]}[代码] [代码]</script>[代码] ============================ 补充,问题已经解决了,下面是一些心得: 在做小程序授权登录时, 不同的人有不同的实现细节, 导致有各种不一致的描述, 与他人进行沟通讨论的时候, 思想很难保持同步。 ### 微信官网登录时序图示例 ![](https://images2018.cnblogs.com/blog/1303135/201809/1303135-20180906120150079-810857681.png) ### `wx.login()`会刷新 session_key 吗 ![](https://images2018.cnblogs.com/blog/1303135/201809/1303135-20180906211103650-366063863.png) 下面是我连续3次测试的结果, 可以看出三个不同的 code 得到相同 session_key: ``` | code | session_key | | - | - | | 061AlTTl1NN1Xk0ZmcUl1iZ0Ul1AlTTi | eTVWziFnhu2vG+iVrjDOqA== | 071Rl0SD0Dd7Sc2hkkOD0asORD0Rl0SW | eTVWziFnhu2vG+iVrjDOqA== | 071wl53j2qtQCH0SfKZi2SVN2j2wl53d | eTVWziFnhu2vG+iVrjDOqA== ``` 我决定等待10分钟之后再去尝试: ``` code_xxx LMiKHyNLaGHidXqSsg4Ung== ``` 果然 session_key 发生了变化,这和[官网文档说明](https://developers.weixin.qq.com/miniprogram/dev/api/signature.html#wxchecksessionobject)符合: > 原文:微信不会把session_key的有效期告知开发者。我们会根据用户使用小程序的行为对session_key进行续期。用户越频繁使用小程序,session_key有效期越长。 ### 数据签名校验? ![](https://images2018.cnblogs.com/blog/1303135/201809/1303135-20180906213036296-17637551.png) 签名算法 `signature = sha1( rawData + session_key )` ,意味着两个参数都相同,或者两个参数都不同,其签名才可能一致。所有我一个大胆的尝试,如果我更改我的性别或者昵称,那么前端得到的rawData 也会发生变更,session_key 也会发生变更,才能通过签名验证。可惜的是我更改了我的用户信息之后,通过调试发现 rawData 并没有立即发生变更。 ### 我个人当前的做法 每次涉及到解密用户信息时,前端都会重新回去授权 code ,服务端使用 code 获取 session_key,然后再解密。 虽然微信小程序官网有说明 code 的有效期为5分钟,经过测试发现不止5分钟(我发现10分钟也没过期)。但是为了避免 code 过期,还是要注意相关的逻辑。 ### 总结 希望上面的几个比较重要的点能够帮助你,同时希望你留言一起讨论大家的实现区别,谢谢您的阅读!
2018-09-27 - python3 解密运动步数报错
小程序客户端调用 wx.getWeRunData 返回加密数据,回传给后台解密的时候报错,如下: >>> WXBizDataCrypt(app_id, session_key).decrypt(encrypted_data, iv) Traceback (most recent call last): File "<console>", line 1, in <module> File "/Users/stranger/workspace/ch_python/ch_common/weixin/interface.py", line 625, in decrypt decrypted = json.loads(self._unpad(cipher.decrypt(encryptedData))) File "/usr/local/Cellar/python3/3.6.3/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/__init__.py", line 349, in loads s = s.decode(detect_encoding(s), 'surrogatepass') UnicodeDecodeError: 'utf-8' codec can't decode bytes in position 0-1: invalid continuation byte 相关数据: app_id = 'wx808763acbb99479b' session_key = 'VIR7ke64cW5V10si9wGEHA==' encrypted_data = 'QbR34om5uf83A1c2bItWCRuaYesEExCjPZL7yTBd9WbzrVZOnnMRj6joLrh0nYFaoXfv4XEm6/pMlkF9LxxClbyzumFKXRJo/bMlzH3rcqsuzUfpz+FtGFjLixBVUW+9yr6B9V1h7mAlmpHjIN8DAN5nnekscnQDvnIxgOtcSayYjOH+i1vH8e5l9bYdKeSFJIFffnaFPBF3a3RHXOdGLzckPVyUD0XxY5HxSyGmi1kTty7whia8WaC4+UR2Hh/3RJbpk37dpAJ0YtdU1bkDBJV3/eRJGRuBHDoKF2Qad+rKiNBojLI1WMUZsVTb1loIEKjn2OjZSqvKCr2vvVZ4jXyQ+RKMdjVKBfA4kNyjUiEbI01jHwVvKUSll/szt1CxWpIYNPCT9bgqFMetUqklHhKkZgckp9NgmNqWZ5sNtcEknKpcG8lfvQOsSPZHf6P3ej1Zd1jDtn1v9UUcIJHhGULj0frvHfyTuwsL54nGGx8bdj7vW4SUwEE3mAyP0szPQgXshIAfa/AJt6wWaGzzq8xdtXyRm6VVZaK05PYcglx4EGXU3/acXllPZMxyqs4+nDB374oLZ7qBYj27TCA0s67AQTOBjUrnP4Yl0D8GqHGusIYLUtuCYB7VscdXVASY4gFs1E758B8y864UDI0dfpVpm7ZkRfT4Xvs5W+EWBI8lPSW/NqoIx2V4gZtdyBwkxuZwM5voZFxS+3H0Oj3xQRUvcA6C7EaZxGVgFn15xBq8s2T58MyAT7hTF4C4DrqQO8AaPPRxWjj8P9+J0AXngoEgPv5Kng35rzDDn7Z8Miz7F4m2pmlPu9+r0+ylW3TiiGmbYwu2KW8ou3iSY6SNV9lX6eFg+ia16//d/fw/rH/pgEttrUTov3vb6nqAA5KOSl/TdzUYy9NOZBMX1OUe7iJklGwtb6OVGhazwCEDBei1rGTJ8DmwuYO/20OcRrPWJPRGCubtJDTPMhFBRsRxNw2I6rf4jFEWhZLOQtpv7oykPCYo3lLHNa/mGgDct6KcaX14k/k0zhf/kHXKRbx1Q02zPgDty+mTREqdz0jNzgDtznESgkIvCmRn6Og6rUi+TcYA8eGMfHTIFsonyqH9dcKir7zG82Lk4KvV4k2jWMdqzvFEBFmOnoqK/AWdNH1dSKd2uNxfCzaP8l1Zml9ZxGx8jJ0ZTwC4cc1ubj8iLwquvzNNX8uqKxMDQnsoyUTavVdQeEZ3Qk2S4zKKiHalsbLr/mXavwNqJV8chxe04Y2DOUkW4X8YIImgkVJOVt/3ydt5gPl0fNrrNB8H6Bc4bkBcywVRZoZAEUmoKwTWzPty25OQcyp3U2VTN44OBwO2xaHS1xUMEinNh/kbd17bx5MpFEC6xr9EHt9JlaAGjDsdtAtKpckJTt6Q5SOFMTsk+H5pq4RTIGckiEzzEOkzjago6dDASCTVvfa03DWZlXMm8c6OgalhI08vQ3wCAuD5rBcYblzOeGJAX3Mo8zU7mPmgza8wJqviqfsFvST7LEQGGKMpvyfFEs3htSTR32kAAyAvQ91FL6+CbIovYSq3PHOyv9Th0ppmNkQKwflwI6hkL2NUbMq+I21oWOwKM+f2RUPnuSBmYg2n5spCDfr29w==' iv = 'DlSrfDlXCJBcHwSKxINmbA==' 帮忙看看啥原因吧,偶现的,99%用户都没问题,但是一天总有几次报错
2018-08-02