网页手机号抓取程序(官方流程图小程序使用方法和流程介绍String)

优采云 发布时间: 2021-12-15 16:16

  网页手机号抓取程序(官方流程图小程序使用方法和流程介绍String)

  最近在做小程序开发,遇到了很多坑。拿到小程序的手机号并绑定后,遇到了一个很傻的坑。

  工艺介绍

  

  官方流程图

  

  小程序使用方法

  组件open-type的值需要设置为getPhoneNumber。用户点击同意后,可以通过bindgetphonenumber事件回调获取微信服务器返回的加密数据,然后第三方服务器结合session_key和app_id进行解密,得到电话号码。

  返回参数说明

  参数类型说明

  加密数据

  细绳

  包括敏感数据在内的完整用户信息的加密数据,详见

  四

  细绳

  加密算法的初始向量,详见

  小程序收到这些参数后,将code、encryptedData、iv发送到后台,然后在后台解密

  后台解密

  解密前需要session_key配合解密,所以先通过code获取session_key

  

# 获取openid,session_key

# Appid为小程序id

openid_url = "https://api.weixin.qq.com/sns/jscode2session?appid=%s&secret=%s&js_code=%s&grant_type=authorization_code" % (

APP_ID, APP_KEY, code

)

req = requests.get(openid_url)

rep = req.json()

session_key = rep.get("session_key")

  得到session_key、encryptedData、iv后,就可以进行解密了。python2的实现代码如下:

  

import base64

import json

from Crypto.Cipher import AES

class WXBizDataCrypt:

def __init__(self, appId, sessionKey):

self.appId = appId

self.sessionKey = sessionKey

def decrypt(self, encryptedData, iv):

# base64 decode

sessionKey = base64.b64decode(self.sessionKey)

encryptedData = base64.b64decode(encryptedData)

iv = base64.b64decode(iv)

cipher = AES.new(sessionKey, AES.MODE_CBC, iv)

decrypted = json.loads(self._unpad(cipher.decrypt(encryptedData)))

if decrypted['watermark']['appid'] != self.appId:

raise Exception('Invalid Buffer')

return decrypted

def _unpad(self, s):

return s[:-ord(s[len(s)-1:])]

  调用参数

  

# APP_ID为小程序id不是openid!!!

pc = wx_jm(APP_ID, session_key)

res = pc.decrypt(encryptedData, iv)

  参数详情参考微信官方文档

  微信官方提供多种编程语言的示例代码。点击下载

  返回数据格式

  

{

"phoneNumber": "13580006666",

"purePhoneNumber": "13580006666",

"countryCode": "86",

"watermark":

{

"appid":"APPID",

"timestamp":TIMESTAMP

}

}

  总结

  以上就是小编为python获取微信小程序手机号并绑定的坑。我希望它会对你有所帮助。如有问题,请给我留言,小编会及时回复您。非常感谢大家对脸圈教程网站的支持!

0 个评论

要回复文章请先登录注册


官方客服QQ群

微信人工客服

QQ人工客服


线