最近在做一款微信小程序,需要获取用户手机号,具体步骤如下:

流程图:

1、首先,客户端调用wx.login,回调数据了包含jscode,用于获取openid(用户唯一标识)和sessionkey(会话密钥)。

2、拿到jscode后,将其发送给服务端,服务端拿它与微信服务端做交互获取openid和sessionkey。具体获取方法如下:

(1)需要写一个HttpUrlConnection工具类:

public class MyHttpUrlConnection {

private final int mTimeout = 10000; // 超时时间

/**

* get访问

*/

public String[] requestJson(String url) {

return request(url);

}

private String[] request(String connurl) {

String[] resultStr = new String[]{"", ""};

StringBuilder resultData = new StringBuilder("");

HttpURLConnection conn = null;

try {

URL url = new URL(connurl);

conn = (HttpURLConnection) url.openConnection();

conn.setRequestMethod("GET");

conn.setUseCaches(false);

conn.setConnectTimeout(mTimeout);

conn.connect();

int resultCode = conn.getResponseCode();

InputStreamReader in;

if (resultCode == 200) {

in = new InputStreamReader(conn.getInputStream());

BufferedReader buffer = new BufferedReader(in);

String inputLine;

while ((inputLine = buffer.readLine()) != null) {

resultData.append(inputLine);

resultData.append("\n");

}

buffer.close();

in.close();

}

resultStr[0] = resultData.toString();

resultStr[1] = resultCode + "";

} catch (Exception e) {

e.printStackTrace();

} finally {

if (conn != null) {

conn.disconnect();

}

}

return resultStr;

}

}

(2)然后通过这个工具类与微信服务器建立连接,获取想要的数据:

String url = "https://api.weixin.qq.com/sns/jscode2session?appid=""&secret=""&js_code="

+ jsCode + "&grant_type=authorization_code";

String res[] = connection.requestJson(url);

System.out.println(res[0]);

JSONObject object = JSON.parseObject(res[0]);

String openId = object.getString("openid");

String session_key = object.getString("session_key");

其中appid和secret都是自己开发者账号里可以查询到的,js_code是客户端发过来的,这样在返回的数据中就可以获取sessionkey。

3、服务器A拿到sessionkey后,生成一个随机数我们叫3rdsession,以3rdSessionId为key,以sessionkey + openid为value缓存到redis或memcached中;因为微信团队不建议直接将sessionkey在网络上传输,由开发者自行生成唯一键与sessionkey关联。其作用是: (1)、将3rdSessionId返回给客户端,维护小程序登录态。

(2)、通过3rdSessionId找到用户sessionkey和openid。

4、客户端拿到3rdSessionId后缓存到storage,

5、通过wx.getUserIinfo可以获取到用户敏感数据encryptedData 。

6、客户端将encryptedData、3rdSessionId和偏移量一起发送到服务器A

7、服务器A根据3rdSessionId从缓存中获取session_key

8、在服务器A使用AES解密encryptedData,从而实现用户敏感数据解密。

解密数据需要用到的参数有三个,分别是:

1、encryptedData(密文)

2、iv(向量)

3、aesKey(密钥)也就是sessionkey

在解密的时候要将上述三个变量做Base64解码:

byte[] encrypData = UtilEngine.decode(encData);

byte[] ivData = UtilEngine.decode(iv);

byte[] sessionKey = UtilEngine.decode(session_key);

然后使用AES解密方法进行解密:

public static byte[] decrypt(byte[] key, byte[] iv, byte[] encData)

throws NoSuchPaddingException, NoSuchAlgorithmException, InvalidAlgorithmParameterException,

InvalidKeyException, BadPaddingException, IllegalBlockSizeException {

AlgorithmParameterSpec ivSpec = new IvParameterSpec(iv);

Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");

SecretKeySpec keySpec = new SecretKeySpec(key, "AES");

cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec);

return cipher.doFinal(encData);

}

这样在返回的数据中就可以拿到用户的手机号。

微信小程序python解析获取用户手机号_微信小程序获取用户手机号详解相关推荐

  1. python解析二维码_Python二维码生成识别实例详解

    前言 在 JavaWeb 开发中,一般使用 Zxing 来生成和识别二维码,但是,Zxing 的识别有点差强人意,不少相对模糊的二维码识别率很低.不过就最新版本的测试来说,识别率有了现显著提高. 对比 ...

  2. 单片机程序配置成开漏输出_单片机I/O开漏输出详解

    开漏输出:输出端相当于三极管的集电极. 要得到高电平状态需要上拉电阻才行. 适合于做电流型的驱动,其吸收电流的能力相对强(一般20ma以内). 我们先来说说集电极开路输出的结构.集电极开路输出的结构如 ...

  3. python中define的用法_#define用法,C语言#define详解

    C语言中,可以用 #define 定义一个标识符来表示一个常量.其特点是:定义的标识符不占内存,只是一个临时的符号,预编译后这个符号就不存在了. 预编译又叫预处理.预编译不是编译,而是编译前的处理.这 ...

  4. 视频教程-微信小程序系统教程python版[3/3阶段]_微信小程序支付-手游开发

    微信小程序系统教程python版[3/3阶段]_微信小程序支付 微信企业号星级会员.10多年软件从业经历,国家级软件项目负责人,主要从事软件研发.软件企业员工技能培训.已经取得计算机技术与软件资格考试 ...

  5. 怎么往integer型数组添加数据_用户日活月活怎么统计 - Redis HyperLogLog 详解

    HyperLogLog 是一种概率数据结构,用来估算数据的基数.数据集可以是网站访客的 IP 地址,E-mail 邮箱或者用户 ID. 基数就是指一个集合中不同值的数目,比如 a, b, c, d 的 ...

  6. python调用shell脚本的参数_使用python执行shell脚本 并动态传参 及subprocess的使用详解

    最近工作需求中 有遇到这个情况 在web端获取配置文件内容 及 往shell 脚本中动态传入参数 执行shell脚本这个有多种方法 最后还是选择了subprocess这个python标准库 subpr ...

  7. Python的Django框架中forms表单类的使用方法详解2

    用户表单是Web端的一项基本功能,大而全的Django框架中自然带有现成的基础form对象,本文就Python的Django框架中forms表单类的使用方法详解. Form表单的功能 自动生成HTML ...

  8. python整数池_对Python中小整数对象池和大整数对象池的使用详解

    1. 小整数对象池 整数在程序中的使用非常广泛,Python为了优化速度,使用了小整数对象池, 避免为整数频繁申请和销毁内存空间. Python 对小整数的定义是 [-5, 256] 这些整数对象是提 ...

  9. python符号格式化设置区间_Python 数值区间处理_对interval 库的快速入门详解

    使用 Python 进行数据处理的时候,常常会遇到判断一个数是否在一个区间内的操作.我们可以使用 if else 进行判断,但是,既然使用了 Python,那我们当然是想找一下有没有现成的轮子可以用. ...

  10. [python opencv 计算机视觉零基础到实战] 四、了解色彩空间及其详解

    一.学习目标 了解什么是色彩空间 了解opencv中色彩空间的转换 目录 [python opencv 计算机视觉零基础到实战] 一.opencv的helloworld [[python opencv ...

最新文章

  1. AI一分钟 | 小鹏汽车回应前苹果员工窃取商业机密:积极配合相关调查
  2. android 开发工具篇之android studio(二)使用篇
  3. 精确记算程序的运行时间或者某段代码的运行时间
  4. 我用 tensorflow 实现的“一个神经聊天模型”:一个基于深度学习的聊天机器人
  5. OSPF在企业网的应用
  6. 关于利用IBERT核对GTX收发器板级测试的原理与过程详解
  7. 一个人到底申请几张信用卡最合适?
  8. 2017蓝桥杯决赛-发现环 数据结构|搜索
  9. 壮观霉素抗性基因原理_基因组学深入挖掘·研究方案(下篇)
  10. Socket简单介绍(通过NSStream)
  11. C#中字符串操作函数
  12. 如何在github上搭建一个免费的 无限流量的静态网页博客Github pages
  13. lgg8各个版本_LG正式推出G8SThinQ 搭载骁龙855
  14. 让你的Windows系统时光倒流
  15. GD32实战16__备份域
  16. VS创建 Win32 应用程序(实现窗口的创建)
  17. 阿里校招 数据分析师 笔试题
  18. python爬虫--Scrapy框架--Scrapy+selenium实现动态爬取
  19. kpu 处理器_深度学习及 KPU 基础知识
  20. ACM MM 2020大奖项出炉!南开获最佳论文奖,西安交大获最佳学生论文奖

热门文章

  1. 爱淘php,PHP文件操作实现代码
  2. 十大著名黑客——罗伯特-莫里斯
  3. 现在学python怎么样-大家都是怎么样自学python的?
  4. H5页面,js监听安卓手机返回按键操作,禁用返回按键操作。
  5. 苹果电脑macos Monterey 12.3.1(21E258)dmg原版引导版镜像下载
  6. Ansys Zemax | 如何设计单透镜 第三部分:优化
  7. java 远程调试 端口_JAVA远程调试
  8. PGD 中 min-max 问题
  9. robotiq 2f 140安装在UR3机械臂后面在gazebo仿真中散架、抖动
  10. Ansys-静力学分析-平面桁架学习心得