微信扫码登录_JAVA

一、需求

 在PC端的登录页面加个微信扫码的按钮,点击按钮弹出二维码,实现微信扫码登录网站的功能。如图:

微信扫码登录_JAVA_第1张图片

微信扫码登录_JAVA_第2张图片

二、调研

扫码登录属于微信开放平台提供的API,不是微信公众平台。这里需要注册等配置,暂不赘述。

同时也要注意,如果你也需要微信公众号内的登录授权操作,那么用户唯一标识不应该是openId,而应该是unionId,因为微信公众平台和微信开放平台的openId是不一样的。

微信扫码登录_JAVA_第3张图片

三、开始开发

1.后台新增生成二维码图片的接口,因为我这里扫码后跳转的地址不是固定的,所以也用到了这个state参数,如果固定可以写死这个跳转地址。

 /**
     * 返回二维码
     *
     * @param state 扫码成功后跳转的链接
     * @return
     */
    @ResponseBody
    @RequestMapping(value = "/getQrCode", method = RequestMethod.GET)
    public String getQrCode(String state) {
        try {
            state = StringUtils.isBlank(state) ? "state" : state;
            //redirectUri 是扫码回调的地址 下一个方法oauth
            String encodeUri = URLEncoder.encode(redirectUri, "UTF-8");
            String url = "https://open.weixin.qq.com/connect/qrconnect?" +
                    "appid={appId}&redirect_uri={redirect_uri}&response_type=code&scope=snsapi_login&state={state}#wechat_redirect";
            String urlReplace = url.replace("{appId}", appId).replace("{redirect_uri}", encodeUri)
                    .replace("{state}", state);
            log.info("-----微信开放平台扫码登录url-----" + urlReplace);
            return urlReplace;
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

2.前端调用接口,打开二维码的页面

   //wx_login 是按钮的id
 $("#wx_login").on("click", function () {
            $.ajax({
                url: '二维码接口/getQrCode',
                async: true,
                dataType: 'json',
                type: 'get',
                success: function (data) {
                    location.href = data;
                }
            });
        });

3.后端新增扫描二维码回调的方法,其中主要做了:

 

①:微信后台回调该方法,传入code参数,用来获取 accessToken和openId

②:调用微信授权接口即getUserAuthInfo,获取 accessToken和openId

请求方式:GET

URL:   https://api.weixin.qqcom/sns/oauth2/access_token?appid={APP_ID}&secret={APP_SECRET}&code={CODE}&grant_type=authorization_code

 

③:调用微信用户信息接口即getWxAuthUser,获取用户的unionId,昵称等信息。

请求方式:GET

URL:  https://api.weixin.qq.com/sns/userinfo?access_token={ACCESS_TOKEN}&openid={OPENID}&lang=zh_CN

/**
     * pc扫码登录跳转
     *
     * @return
     */
    @RequestMapping(value = "/oauth", method = RequestMethod.GET)
    public RedirectView oauth(HttpServletRequest request, HttpServletResponse response) {
        String code = request.getParameter("code");
        String state = request.getParameter("state");
        //appId appSecret 在微信开放平台找到
        Map userAuthMap = userInfoService.getUserAuthInfo(code, appId, appSecret);
        String accessToken = userAuthMap.get("access_token");
        String openid = userAuthMap.get("openid");
        WxAuthUser wxAuthUser = WechatUtil.getWxAuthUser(accessToken, openid);
        if (wxAuthUser == null) {
            return null;
        }
        //你的登录逻辑
        String jsonResult = doLogin(wxAuthUser);
        log.info("-----微信开放平台扫码跳转url-----" + state);
        RedirectView redirectView = new RedirectView(state);
        redirectView.setStatusCode(HttpStatus.MOVED_PERMANENTLY);
        return redirectView;
    }

 

最后:总体来说流程比较简单,所以代码贴的不是很全,但是都有讲到。

有一些注意的点比如微信开放平台需要绑定公众号回调域名等配置。

你可能感兴趣的:(第三方平台接入)