登录流程时序:

说明

  1. 调用 wx.login() 获取 临时登录凭证code ,并回传到开发者服务器。
  2. 调用 auth.code2Session 接口,换取 用户唯一标识 OpenID 、 用户在微信开放平台帐号下的唯一标识UnionID(若当前小程序已绑定到微信开放平台帐号) 和 会话密钥 session_key

之后开发者服务器可以根据用户标识来生成自定义登录态,用于后续业务逻辑中前后端交互时识别用户身份。

注意事项

  1. 会话密钥 session_key 是对用户数据进行 加密签名 的密钥。为了应用自身的数据安全,开发者服务器不应该把会话密钥下发到小程序,也不应该对外提供这个密钥
  2. 临时登录凭证 code 只能使用一次

获取OpenId:

    @PostMapping("/getOpeId")//获取openIdpublic String getOpeId(@RequestBody JSONObject js_code) {String code = js_code.getString("js_code");// 小程序唯一标识 (在微信小程序管理后台获取)String appid = "";// 小程序的 app secret (在微信小程序管理后台获取)String secret = "";// 授权(必填)String grant_type = "authorization_code";// 向微信服务器 使用登录凭证 code 获取 session_key 和 openid// 请求参数String params = "appid=" + appid + "&secret=" + secret + "&js_code=" + code + "&grant_type=" + grant_type;// 发送请求String sr = HttpRequest.sendGet("https://api.weixin.qq.com/sns/jscode2session", params);// 解析相应内容(转换成json对象)JSONObject json = JSONObject.parseObject(sr);// 获取会话密钥(session_key)
//        String session_key = json.get("session_key").toString();// 用户的唯一标识(openid)String openid = (String) json.get("openid");return openid;}

获取手机号:

    @PostMapping("/getPhoneNum")//获取手机号public Object getPhoneNum(@RequestBody JSONObject js_code){// 获取token// 小程序唯一标识 (在微信小程序管理后台获取)String appid = "";// 小程序的 app secret (在微信小程序管理后台获取)String secret = "";// 授权(必填)String grant_type = "client_credential";//向微信服务器 使用登录凭证 code 获取 session_key 和 openid// 请求参数String params2 = "appid=" + appid + "&secret=" + secret + "&grant_type=" + grant_type;// 发送请求String sr2 = HttpRequest.sendGet("https://api.weixin.qq.com/cgi-bin/token", params2);// 解析相应内容(转换成json对象)JSONObject json2 = JSONObject.parseObject(sr2);String access_token = json2.getString("access_token");//使用获取到的token和接受到的code像微信获取手机号String code = js_code.getString("js_code");JSONObject jsonObject = new JSONObject();jsonObject.put("code",code);String url = ("https://api.weixin.qq.com/wxa/business/getuserphonenumber?access_token="+access_token);String sr3 = HttpRequest.sendPost(url,jsonObject);JSONObject phone_info = JSONObject.parseObject(sr3);return phone_info;}

说明:appid和secret需要在微信小程序管理后台获取

HTTP工具类:

import com.alibaba.fastjson.JSONObject;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.ContentType;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.URL;
import java.net.URLConnection;
import java.util.List;
import java.util.Map;public class HttpRequest {public static void main(String[] args) {//发送 GET 请求String s = HttpRequest.sendGet("http://v.qq.com/x/cover/kvehb7okfxqstmc.html?vid=e01957zem6o", "");System.out.println(s);//发送 POST 请求
//        String sr=HttpRequest.sendPost("http://www.toutiao.com/stream/widget/local_weather/data/?city=%E4%B8%8A%E6%B5%B7", "");
//        JSONObject json = JSONObject.parseObject(sr);
//        System.out.println(json.get("data"));}/*** 向指定URL发送GET方法的请求** @param url   发送请求的URL* @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。* @return URL 所代表远程资源的响应结果*/public static String sendGet(String url, String param) {String result = "";BufferedReader in = null;try {String urlNameString = url + "?" + param;URL realUrl = new URL(urlNameString);// 打开和URL之间的连接URLConnection connection = realUrl.openConnection();// 设置通用的请求属性connection.setRequestProperty("accept", "*/*");connection.setRequestProperty("connection", "Keep-Alive");connection.setRequestProperty("user-agent","Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");// 建立实际的连接connection.connect();// 获取所有响应头字段Map<String, List<String>> map = connection.getHeaderFields();// 遍历所有的响应头字段for (String key : map.keySet()) {System.out.println(key + "--->" + map.get(key));}// 定义 BufferedReader输入流来读取URL的响应in = new BufferedReader(new InputStreamReader(connection.getInputStream()));String line;while ((line = in.readLine()) != null) {result += line;}} catch (Exception e) {System.out.println("发送GET请求出现异常!" + e);e.printStackTrace();}// 使用finally块来关闭输入流finally {try {if (in != null) {in.close();}} catch (Exception e2) {e2.printStackTrace();}}return result;}/*** 向指定 URL 发送POST方法的请求** @param url   发送请求的 URL* @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。* @return 所代表远程资源的响应结果*/public static String sendPost(String url, JSONObject param) {PrintWriter out = null;BufferedReader in = null;String result = "";try {URL realUrl = new URL(url);// 打开和URL之间的连接URLConnection conn = realUrl.openConnection();// 设置通用的请求属性conn.setRequestProperty("accept", "*/*");conn.setRequestProperty("connection", "Keep-Alive");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()));String line;while ((line = in.readLine()) != null) {result += line;}} catch (Exception e) {System.out.println("发送 POST 请求出现异常!" + e);e.printStackTrace();}//使用finally块来关闭输出流、输入流finally {try {if (out != null) {out.close();}if (in != null) {in.close();}} catch (IOException ex) {ex.printStackTrace();}}return result;}public static String sendPost2(String url, String data) {String response = null;try {CloseableHttpClient httpclient = null;CloseableHttpResponse httpresponse = null;try {httpclient = HttpClients.createDefault();HttpPost httppost = new HttpPost(url);StringEntity stringentity = new StringEntity(data,ContentType.create("text/json", "UTF-8"));httppost.setEntity(stringentity);httpresponse = httpclient.execute(httppost);response = EntityUtils.toString(httpresponse.getEntity());} finally {if (httpclient != null) {httpclient.close();}if (httpresponse != null) {httpresponse.close();}}} catch (Exception e) {e.printStackTrace();}return response;}
}

相关文档:小程序登录 | 微信开放文档

Java实现微信小程序登录注册:获取OpenId和手机号相关推荐

  1. 小程序登录注册获取openid解密手机号服务端实现

    文章目录 前言 一.openId是什么 1.如何确认微信和小程序唯一身份 2.为什么使用openId 3.如何获得openId 1:前端示例代码 2:服务端示例代码 二.解密微信绑定手机号 1:前端示 ...

  2. java微信小程序接口openid过期_Java微信小程序登录接口获取openid

    根据官方文档,wx.login()的回调函数中,需要我们传递生成的用户登录凭证到code2accessToken的接口中 小程序登录方法 code2accessToken的方法中要求传入如下参数 co ...

  3. java后端微信小程序登录与注册

    java后端微信小程序登录与注册&微信登录授权 分析: 微信小程序用户表 的字段来源于微信服务器 , 必须想办法去获取到对应的用户信息 找到微信开放平台: 微信开放平台 以下是微信开放平台给出 ...

  4. 微信小程序登录注册——云开发

    微信小程序登录注册页面_云开发_调用云数据库 源代码下载https://download.csdn.net/download/lujiebin/11241027 1.界面展示 2.代码 1.云开发初始 ...

  5. java版微信小程序登录商城源码Spring Cloud+Redis+MQ+VR全景+b2b2c多商家入驻前后端分离商城源码

    @源码地址来源: https://minglisoft.cn/honghu2/business.html 微信小程序登录代码: /*** Copyright © 2012-2017 <a hre ...

  6. java版微信小程序登录商城源码Spring Cloud+Spring Boot+mybatis+security+uniapp+Redis+MQ+VR全景+b2b2c多商家入驻前后端分离商城源码

    @源码地址来源: https://minglisoft.cn/honghu2/business.html 微信小程序登录代码: /*** Copyright © 2012-2017 <a hre ...

  7. java版微信小程序登录商城源码MQ+VR全景+b2b2c多商家入驻前后端分离商城源码

    @源码地址来源: https://minglisoft.cn/honghu2/business.html 微信小程序登录代码: /*** Copyright © 2012-2017 <a hre ...

  8. 微信小程序自动注册获取token

    小程序 app.js import {Cache } from './utils/cache.js'; const cache = new Cache(7200) // app.js App({onL ...

  9. sessionkey 微信小程序获取_微信小程序登录,获取code,获取openid,获取session_key...

    微信小程序登录 wx.login(Object object) 调用接口获取登录凭证(code).通过凭证进而换取用户登录态信息,包括用户的唯一标识(openid)及本次登录的会话密钥(session ...

最新文章

  1. 美团确定进军自动驾驶,滴滴如何应对?
  2. 智能工厂的关键:基于机器学习的工业视觉
  3. 类风湿性关节炎患者腕关节的多普勒超声积分与OMERACT RAMRIS骨髓水肿和滑膜相关...
  4. 你组织的安全策略阻止未经身份验证的来宾访问_你不能访问此共享文件夹,因为你组织的安全策略阻止未经身份验证来宾访问。...
  5. 【爬坑】Vim 文档加密 解密
  6. django-rest-framework第一次使用使用常见问题
  7. 数据科学和人工智能技术笔记 三、数据预处理
  8. Python numpy学习笔记(一)
  9. Atitit  OOCSS vs bem
  10. 智能管家项目总结(2)
  11. mysql慢sql分析平台_慢SQL分析工具 - __KK的个人空间 - OSCHINA - 中文开源技术交流社区...
  12. 计算机组成原理语言方框图,计算机组成原理实验报告3 语言方框图
  13. windows+中标麒麟双系统启动优先顺序调整方法
  14. win7计算机里没有桌面快捷方式,Win7桌面快捷方式图标消失的解决办法
  15. 滑动窗口有关的算法面试题
  16. android自定义标尺,Android自定义标尺滑动选择值效果
  17. 忍者必须死3突然服务器维修,《忍者必须死3》3月25日停服维护公告
  18. 我爱你用计算机按出来,iPhone计算器魔法技巧 简单几步获取对方手机号
  19. 产品实习之竞品分析报告篇
  20. 网络安全:大数据问题

热门文章

  1. UltraEdit文本替换
  2. wpf 日期选择对话窗_WPF 4 日历控件(Calendar)
  3. Python(Pygame)图像详解
  4. win7系统调节鼠标灵敏度的方法分享
  5. BZOJ2245: [SDOI2011]工作安排
  6. 系统分析与设计——状态图画法
  7. openresty 静态库_Nginx核心知识100讲学习笔记(陶辉)Nginx架构基础(四)
  8. 对于有抱负的软件开发人员:采访是一条两条路
  9. BFT-DPoS共识算法讲解
  10. 三维激光扫描技术简介