java后端集成微信扫码登录

本代码从项目复制出来的,未验证,请自行验证吧

工具类

package com.jeeplus.modules.utils;

import com.alibaba.fastjson.JSONObject;
import lombok.extern.slf4j.Slf4j;
import org.springframework.http.*;
import org.springframework.web.client.RestTemplate;

@Slf4j
public class WXLoginUtil {
    private static final String APPID = "xxxxxxxxxxxx";
    private static final String APPSECRET = "xxxxxxxxxxxxxxxxxxxx";

    /**
     * @Title: getAccessToken
     * @Description: 获取接口调用凭证
     * @param: @return
     * @return: String
     */
    public static JSONObject getAccessToken(String code) {
        RestTemplate restTemplate = new RestTemplate();
        String url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid="
                + APPID + "&secret=" + APPSECRET + "&code=" + code + "&grant_type=authorization_code";

        HttpHeaders headers = new HttpHeaders();
        headers.setContentType(MediaType.APPLICATION_JSON_UTF8);
        HttpEntity<String> entity = new HttpEntity<String>(headers);
        ResponseEntity<String> responseEntity = restTemplate.exchange(url, HttpMethod.GET, entity, String.class);
        String body = responseEntity.getBody();
        // 返回结果转换为json对象
        JSONObject jObject = JSONObject.parseObject(body);
        return jObject;
    }

    public static JSONObject getUserInfo(String accessToken, String openid) {
        RestTemplate restTemplate = new RestTemplate();
        String url = "https://api.weixin.qq.com/sns/userinfo?access_token=" + accessToken + "&openid=" + openid + "&lang=zh_CN";

        HttpHeaders headers = new HttpHeaders();
        headers.setContentType(MediaType.APPLICATION_JSON_UTF8);
        HttpEntity<String> entity = new HttpEntity<String>(headers);
        String body = restTemplate.exchange(url, HttpMethod.GET, entity, String.class).getBody();
        // 返回结果转换为json对象
        JSONObject jObject = JSONObject.parseObject(body);
        System.out.println("jObject----------------"+jObject);


        return jObject;
    }
}

调用的时候案例

@RequestMapping("weixinLogin")
    public AjaxJson wxLogin(String accessToken, String openid) {
        AjaxJson json = new AjaxJson();
        // if (StringUtils.isBlank(accessToken)) return AjaxJson.error("accessToken不能为空");
        if (StringUtils.isBlank(openid)) return AjaxJson.error("openid不能为空");
        JSONObject userInfo = WXLoginUtil.getUserInfo(accessToken, openid);
        String unionid = userInfo.getString("unionid");
        System.out.println("unionid------------------------" + unionid);
        Member member = memberService.findOpenid(unionid);
        if (member == null) {
            json.setMsg("请绑定手机号");
            json.setCode(101);
            json.setSuccess(true);
            json.put("unionid", unionid);
            return json;
        }
        if (StringUtils.isNotBlank(member.getCompanyId())) {
            int sum = certificateService.findenterpriseId(member.getCompanyId()).size();
            member.setContents(sum);
        } else {
            member.setContents(0);
        }
        String token = JWTUtils.createAccessToken(member.getId(), member.getPhone(), member.getId());
        return AjaxJson.success("登录成功").put("token", token).put("user", member);
    }

 

posted @ 2022-03-10 15:33  知行IT讲堂  阅读(650)  评论(0编辑  收藏  举报