最近在做小程序开发,在其中也遇到了很多的坑,获取小程序的手机号并绑定就遇到了一个很傻的坑。
流程介绍
官方流程图
<强>小程序使用方法强>
需要将& lt; button>组件开式的值设置为getPhoneNumber,当用户点击并同意之后,可以通过bindgetphonenumber事件回调获取到微信服务器返回的加密数据,然后在第三方服务端结合session_key以及app_id进行解密获取手机号。
& lt;按钮开口=" getPhoneNumber " bindgetphonenumber=癵etPhoneNumber”比;& lt;/button>
返回参数说明
参数 类型 说明 encryptedData 字符串 包括敏感数据在内的完整用户信息的加密数据,详细见加密数据解密算法 4 字符串 加密算法的初始向量,详细见加密数据解密算法
接受到这些参数以后小程序把代码,encryptedData,第四发给后台,然后后台解密
<强>后台解密强>
在解密以前需要session_key进行配合解密,所以首先通过代码获取session_key
#获取openid, session_key # Appid为小程序id openid_url=" https://api.weixin.qq.com/sns/jscode2session& # 63; appid=% s&秘密=% s& js_code=% s& grant_type=authorization_code " % ( APP_ID APP_KEY,代码 ) 要求=requests.get (openid_url) 代表=req.json () session_key=rep.get (session_key)
在得到session_key encryptedData, iv以后就可以进行解密了,python2实现代码如下:
进口base64 进口json 从加密。进口AES密码 类WXBizDataCrypt: def __init__(自我、appId sessionKey): 自我。appId=appId 自我。sessionKey=sessionKey def解密(自我、encryptedData iv): # base64解码 sessionKey=base64.b64decode (self.sessionKey) encryptedData=https://www.yisu.com/zixun/base64.b64decode (encryptedData) 4=base64.b64decode (iv) 密码=AES。新(sessionKey, AES。MODE_CBC,(四) 解密=json.loads (self._unpad (cipher.decrypt (encryptedData))) 如果解密(“水印”][' appid '] !=self.appId: 提高异常(“无效的缓冲区”) 返回解密 def _unpad(自我,年代): 返回s[:奥德(s [len (s) 1:]))
调用传参
# APP_ID为小程序id不是openid ! ! ! 电脑=wx_jm (APP_ID session_key) encryptedData, res=pc.decrypt (iv)
参数详情参照微信官方文档https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/signature.html
微信官方提供了多种编程语言的示例代码点击下载
返回数据格式
{ “phoneNumber”:“13580006666”, “purePhoneNumber”:“13580006666”, “countryCode”:“86”, “水印”: { :“appid appid”, “时间戳”:时间戳 } }
以上所述是小编给大家介绍的python获取微信小程序手机号并绑定遇到的坑,希望对大家有所帮助,如果大家有任何疑问请给我留的言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!