实现微信授权登录

前期准备

  1. 由于微信回调地址需要一个可访问的地址,所以使用内网穿透 获取到本机的一个临时域名。内网穿透

  2. 微信公众号开发,首先要搞一个公众号,开发阶段可以申请一个公众平台测试账号。
    (进入到微信公众公众平台,找到开发者工具,点开公众平台测试账号)
    获取到appId 和 appSecret
    微信公众平台
    在这里插入图片描述
    将获取到的域名填写到 注意不带http
    在这里插入图片描述

    修改回调域名 这里填写临时域名 同样不带http
    在这里插入图片描述

授权登录

利用授权码方式来授权微信登录 关于Oauth2.0和授权登录

  1. 请求code
 function webAuthLogin() {
        var appId = [[${wxConfig.appId}]];
        var openId = [[${session.openId}]];
        var redirectUri = [[${redirectUri}]];
        if (openId == null) {
            window.location.href = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid='+appId +
                '&redirect_uri='+redirectUri +
                '&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect';
        }else{
            alert("您好:"+userInfo.nickname+",已经授权成功!");
        }
    }

在这里插入图片描述
redirectUri 通过这获取

  1. 获取到返回的code

 //获取openid和access_token的连接
    private static String getOpenId = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=APPSECRET&code=CODE&grant_type=authorization_code";
    //获取用户基本信息的连接
    private static String getUserInfo = "https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN";

 @RequestMapping("getCode")
    public String getCode(String code){
        String getOpenIdUrl = getOpenId.replace("APPID", wxConfig.getAppId()).replace("APPSECRET", wxConfig.getAppSecret()).replace("CODE", code);
        String response = HttpClientUtil.doGet(getOpenIdUrl);
        JSONObject jsonObject = JSONObject.parseObject(response);
        String accessToken = jsonObject.get("access_token") == null ? null :jsonObject.get("access_token").toString();
        String openId = jsonObject.get("openid") == null ? null : jsonObject.get("openid").toString();
        httpSession.setAttribute("accessToken",accessToken);
        httpSession.setAttribute("openId",openId);
        httpSession.setAttribute("userInfo",getUserInfo(openId,accessToken));
        return "redirect:/";
    }

这就是上面redirectUri 回调的地址 参数里面带有code 通过这里可以获取到

  1. 通过code去请求令牌
    这里的令牌就是 通过访问getOpenId 这个链接后 返回的accessToken
    有了这个令牌就可以获取到用户的信息

  2. 获取用户信息

 //获取用户基本信息的连接
    private static String getUserInfo = "https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN";
   */
    private JSONObject getUserInfo(String openId,String accessToken){
        String userInfoUrl = getUserInfo.replace("ACCESS_TOKEN",accessToken).replace("OPENID", openId);
        String userInfo = HttpClientUtil.doGet(userInfoUrl);
        JSONObject jsonObject = JSONObject.parseObject(userInfo);
        return jsonObject;
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值