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);
}

浙公网安备 33010602011771号