微信小程序通过code去获取微信用户的加密信息
今天项目要获取用户信息,我发现官方给的解密demo就是没有java 我ca,我就找了这哥们的 (多谢 @未来之路 这哥们的答案)
一、微信小程序
第一步:调用 wx.login获取code 文档地址
第二步:判断用户是否授权读取用户信息 文档地址
第三步:调用wx.getUserInfo读取用户数据 文档地址
第四步:由于小程序后台授权域名无法授权微信的域名,所以我们只能通过我们自己的服务器去调用微信服务器去获取用户信息,故我们将wx.login获取code 和 wx.getUserInfo 获取的encryptedData与iv 通过wx.request 请求传入后台
服务器返回的数据:
小程序代码:
[html] view plain copy
- //调用登录接口,获取 code
- wx.login({
- success: function (res) {
- wx.getSetting({
- success(setRes) {
- // 判断是否已授权
- if (!setRes.authSetting['scope.userInfo']) {
- // 授权访问
- wx.authorize({
- scope: 'scope.userInfo',
- success() {
- //获取用户信息
- wx.getUserInfo({
- lang: "zh_CN",
- success: function (userRes) {
- //发起网络请求
- wx.request({
- url: config.loginWXUrl,
- data: {
- code: res.code,
- encryptedData: userRes.encryptedData,
- iv: userRes.iv
- },
- header: {
- "Content-Type": "application/x-www-form-urlencoded"
- },
- method: 'POST',
- //服务端的回掉
- success: function (result) {
- var data = result.data.result;
- data.expireTime = nowDate + EXPIRETIME;
- wx.setStorageSync("userInfo", data);
- userInfo = data;
- }
- })
- }
- })
- }
- })
- } else {
- //获取用户信息
- wx.getUserInfo({
- lang: "zh_CN",
- success: function (userRes) {
- //发起网络请求
- wx.request({
- url: config.loginWXUrl,
- data: {
- code: res.code,
- encryptedData: userRes.encryptedData,
- iv: userRes.iv
- },
- header: {
- "Content-Type": "application/x-www-form-urlencoded"
- },
- method: 'POST',
- success: function (result) {
- var data = result.data.result;
- data.expireTime = nowDate + EXPIRETIME;
- wx.setStorageSync("userInfo", data);
- userInfo = data;
- }
- })
- }
- })
- }
- }
- })
- }
- })
二、java服务端
根据code获取openid与解码用户信息 代码
所需要的jar包
[java] view plain copy
- <dependency>
- <groupId>org.codehaus.xfire</groupId>
- <artifactId>xfire-core</artifactId>
- <version>1.2.6</version>
- </dependency>
- <dependency>
- <groupId>org.bouncycastle</groupId>
- <artifactId>bcprov-jdk16</artifactId>
- <version>1.46</version>
- </dependency>
[java] view plain copy
- /**
- * 微信小程序信息获取
- *
- * @author zhy
- */
- public class WXAppletUserInfo {
- private static Logger log = Logger.getLogger(WXAppletUserInfo.class);
- /**
- * 获取微信小程序 session_key 和 openid
- *
- * @author zhy
- * @param code 调用微信登陆返回的Code
- * @return
- */
- public static JSONObject getSessionKeyOropenid(String code){
- //微信端登录code值
- String wxCode = code;
- ResourceBundle resource = ResourceBundle.getBundle("weixin"); //读取属性文件
- String requestUrl = resource.getString("url"); //请求地址 https://api.weixin.qq.com/sns/jscode2session
- Map<String,String> requestUrlParam = new HashMap<String,String>();
- requestUrlParam.put("appid", resource.getString("appId")); //开发者设置中的appId
- requestUrlParam.put("secret", resource.getString("appSecret")); //开发者设置中的appSecret
- requestUrlParam.put("js_code", wxCode); //小程序调用wx.login返回的code
- requestUrlParam.put("grant_type", "authorization_code"); //默认参数
- //发送post请求读取调用微信 https://api.weixin.qq.com/sns/jscode2session 接口获取openid用户唯一标识
- JSONObject jsonObject = JSON.parseObject(UrlUtil.sendPost(requestUrl, requestUrlParam));
- return jsonObject;
- }
- /**
- * 解密用户敏感数据获取用户信息
- *
- * @author zhy
- * @param sessionKey 数据进行加密签名的密钥
- * @param encryptedData 包括敏感数据在内的完整用户信息的加密数据
- * @param iv 加密算法的初始向量
- * @return
- */
- public static JSONObject getUserInfo(String encryptedData,String sessionKey,String iv){
- // 被加密的数据
- byte[] dataByte = Base64.decode(encryptedData);
- // 加密秘钥
- byte[] keyByte = Base64.decode(sessionKey);
- // 偏移量
- byte[] ivByte = Base64.decode(iv);
- try {
- // 如果密钥不足16位,那么就补足. 这个if 中的内容很重要
- int base = 16;
- if (keyByte.length % base != 0) {
- int groups = keyByte.length / base + (keyByte.length % base != 0 ? 1 : 0);
- byte[] temp = new byte[groups * base];
- Arrays.fill(temp, (byte) 0);
- System.arraycopy(keyByte, 0, temp, 0, keyByte.length);
- keyByte = temp;
- }
- // 初始化
- Security.addProvider(new BouncyCastleProvider());
- Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding","BC");
- SecretKeySpec spec = new SecretKeySpec(keyByte, "AES");
- AlgorithmParameters parameters = AlgorithmParameters.getInstance("AES");
- parameters.init(new IvParameterSpec(ivByte));
- cipher.init(Cipher.DECRYPT_MODE, spec, parameters);// 初始化
- byte[] resultByte = cipher.doFinal(dataByte);
- if (null != resultByte && resultByte.length > 0) {
- String result = new String(resultByte, "UTF-8");
- return JSON.parseObject(result);
- }
- } catch (NoSuchAlgorithmException e) {
- log.error(e.getMessage(), e);
- } catch (NoSuchPaddingException e) {
- log.error(e.getMessage(), e);
- } catch (InvalidParameterSpecException e) {
- log.error(e.getMessage(), e);
- } catch (IllegalBlockSizeException e) {
- log.error(e.getMessage(), e);
- } catch (BadPaddingException e) {
- log.error(e.getMessage(), e);
- } catch (UnsupportedEncodingException e) {
- log.error(e.getMessage(), e);
- } catch (InvalidKeyException e) {
- log.error(e.getMessage(), e);
- } catch (InvalidAlgorithmParameterException e) {
- log.error(e.getMessage(), e);
- } catch (NoSuchProviderException e) {
- log.error(e.getMessage(), e);
- }
- return null;
- }
- }
发送请求的代码
[java] view plain copy
- /**
- * 向指定 URL 发送POST方法的请求
- *
- * @param url 发送请求的 URL
- * @param param 请求参数
- * @return 所代表远程资源的响应结果
- */
- ublic static String sendPost(String url, Map<String, ?> paramMap) {
- PrintWriter out = null;
- BufferedReader in = null;
- String result = "";
- String param = "";
- Iterator<String> it = paramMap.keySet().iterator();
- while(it.hasNext()) {
- String key = it.next();
- param += key + "=" + paramMap.get(key) + "&";
- }
- try {
- URL realUrl = new URL(url);
- // 打开和URL之间的连接
- URLConnection conn = realUrl.openConnection();
- // 设置通用的请求属性
- conn.setRequestProperty("accept", "*/*");
- conn.setRequestProperty("connection", "Keep-Alive");
- conn.setRequestProperty("Accept-Charset", "utf-8");
- conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
- // 发送POST请求必须设置如下两行
- conn.setDoOutput(true);
- conn.setDoInput(true);
- // 获取URLConnection对象对应的输出流
- out = new PrintWriter(conn.getOutputStream());
- // 发送请求参数
- out.print(param);
- // flush输出流的缓冲
- out.flush();
- // 定义BufferedReader输入流来读取URL的响应
- in = new BufferedReader(new InputStreamReader(conn.getInputStream(), "UTF-8"));
- String line;
- while ((line = in.readLine()) != null) {
- result += line;
- }
- } catch (Exception e) {
- log.error(e.getMessage(), e);
- }
- //使用finally块来关闭输出流、输入流
- finally{
- try{
- if(out!=null){
- out.close();
- }
- if(in!=null){
- in.close();
- }
- }
- catch(IOException ex){
- ex.printStackTrace();
- }
- }
- return result;
- }
如果大佬们觉得有用的话 请关注一下小弟的副业 淘宝店https://shop135377658.taobao.com/shop/view_shop.htm?spm=a211vu.server-web-home.category.d53.64f02d5879I9Wp&mytmenu=mdianpu&user_number_id=1709908377
微信小程序通过code去获取微信用户的加密信息相关推荐
- uniapp微信小程序授权登录和获取微信绑定的手机号码
uniapp微信小程序授权登录和获取微信绑定的手机号码 弹出授权的弹框 <view class="weixinOk" @tap="getUserProfile&qu ...
- 【微信小程序/实现】实现获取微信个人信息
[微信小程序/实现]实现获取微信个人信息 一.目的:实现获取微信个人的昵称和头像 二.页面过程 三.实现过程 (1)核心代码: (2)完整代码 1. wxml代码 2. wxss代码 3. js代码 ...
- uni-app 微信小程序 用高德sdk获取地理位置,以及天气信息
uni-app 微信小程序采用高德sdk获取地理位置和天气信息主要有以下几个步骤: 1. 注册高德开发者,并获取应用key 概述-微信小程序插件 | 高德地图API 在这个网页最下面,按步骤来就可以了 ...
- 微信小程序-使用云函数获取微信的openid
1.新建云函数login_get_openid 云开发环境初始化参见:https://blog.csdn.net/yuxiao1121/article/details/125222407 新建云函数参 ...
- 微信小程序中,如何获取微信绑定的手机号
获取手机号 获取微信用户绑定的手机号,需先调用wx.login接口. 因为需要用户主动触发才能发起获取手机号接口,所以该功能不由 API 来调用,需用 button 组件的点击来触发. 注意:目前该接 ...
- 获取微信小程序登录code和获取手机号code
// index.ts // 获取应用实例 const app = getApp<IAppOption>()Page({data: {motto: 'Hello World',userIn ...
- 从零开始开发微信小程序(四):微信小程序绑定系统账号并授权登录之后台端...
2019独角兽企业重金招聘Python工程师标准>>> 1. 后台开发环境: 语言:java 框架:springboot 2. 代码示例: package com.zc.wechat ...
- 2000套微信微信小程序源码+抖音微信小程序源码附开源代码
授权微信小程序SDK(authing-wxapp-sdk)适用于微信微信小程序(打开新窗口)基于微信微信小程序环境.可以使用微信微信小程序源码中的所有方法,比如Get,修改用户信息,添加用户自定义字段 ...
- vc++6.0获取磁盘基本信息_微信小程序——常用功能2:微信小程序用户登录,申请用户授权并获取用户基本信息...
微信小程序--常用功能2:申请用户授权并获取用户基本信息 为了更好的用户体验,很多时候我们想要获取用户的基本信息,从而实现将信息呈现到用户界面.给用户划分地域.给用户分类等功能. 但是要想获取用户信息 ...
最新文章
- 汇编语言——正数数组P和负数数组N
- java 中的对象序列化
- 利用虚拟硬盘(把内存当作硬盘)来提高数据库的效率(目前只针对SQL Server 2000)可以提高很多...
- 谷歌网络代理工具_谷歌更新了Dialogflow AI引擎,帮助客户创建更好的虚拟代理...
- python程序代码图片_完整的图片去噪代码(python)
- 大数据之-Hadoop3.x_Yarn_全流程作业---大数据之hadoop3.x工作笔记0143
- GDI+中的图片处理类Image或Bitmap
- canvas绘制圆和弧(三)
- win环境sftp软件_在Windows上使用sftp工具—WinSCP
- 计算机键盘英语单词怎么写,输入单词_如何用电脑键盘打出英文单词需要那种只要一个字母就可以自己弹出单词的那种_淘题吧...
- java试题管理系统
- 【jzoj2173】【DFS】无根树
- 计算机MAR代表什么,MAR是什么意思?
- Python爬虫方法三部曲之二-实战训练
- 安卓手机如何一键去水印
- java计算机毕业设计高校体育场馆管理源码+mysql数据库+系统+lw文档+部署
- clinvar数据库
- labuladong算法小抄中图算法的学习笔记(c++版)
- 如何杀掉“熊猫烧香”
- 计算机xiuli教程,电脑上不去网维修教程
热门文章
- [ 漏洞复现篇 ] Apache Shiro 身份认证绕过漏洞 (CVE-2022-32532)
- 论珊瑚虫并不光彩的历史
- 超人气网站集合,快来pick你中意的吧!
- 2021-05-12 MongoDB面试题 什么情况下需要用到MongoDB的分片
- mycat分片规则详解+实例演示
- JS节点操作——连缀
- 实现一个简单的H5领红包的动画
- SQL SEVER登录失败,无法连接服务器或已成功与服务器建立连接,但是在登录过程中发生错误。(Win10版本,SQL 2019)
- (java)Climbing Stairs
- sketchup 图片转模型_紫天学习星球教学:如何在SU里把JPG图片变成三维模型