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