一.微信公众平台的文档介绍:
1.调用 wx.login() 获取 临时登录凭证code ,并回传到开发者服务器。
2.调用 auth.code2Session 接口,换取 用户唯一标识 OpenID 、 用户在微信开放平台账号下的唯一标识UnionID(若当前小程序已绑定到微信开放平台账号) 和 会话密钥 session_key。
二.具体方法
1.Controller中写登录接口
public Result<UserLoginVO> login(@RequestBody UserLoginDTO userLoginDTO){
log.info("微信用户登录",userLoginDTO);
//微信登录
User user = userService.wxLogin(userLoginDTO);
//添加到vo中
UserLoginVO userLoginVO = UserLoginVO.builder()
.id(user.getId())
.openid(user.getOpenid())
.build();
return Result.success(userLoginVO);
}
UserLoginDTO中只有一个code字段,用来接收传递前端login()获取的code.
由于是post请求,请求体中使用json,需要加上@RequestBody注解.
2.写业务层发送官方给定的请求
public User wxLogin(UserLoginDTO userLoginDTO) {
//调用微信接口服务,获取openid
String openid = getOpenid(userLoginDTO.getCode());
//判断openid是否为空,为空则登录失败
if(openid == null){
throw new LoginFailedException(MessageConstant.LOGIN_FAILED);
}
//判断是否为新用户
User user = userMapper.getByOpenid(openid);
if (user == null){
//是新用户
user = User.builder()
.openid(openid)
.createTime(LocalDateTime.now())
.build();
userMapper.insert(user);
}
//返回用户信息
return user;
}
//抽取获取openid的方法
private String getOpenid(String code){
Map<String,String> map = new HashMap<>();
map.put("appid",weChatProperties.getAppid());
map.put("secret",weChatProperties.getSecret());
//js_code就是前端login返回的code
map.put("js_code", code);
map.put("grant_type","authorization_code");
String json = HttpClientUtil.doGet(WX_LOGIN,map);
JSONObject jsonObject = JSON.parseObject(json);
String openid = jsonObject.getString("openid");
return openid;
使用HttpClientUtil工具类,传入路径和参数
GET https://api.weixin.qq.com/sns/jscode2session
具体参数根据官网要求填写,可以配置在yml文件中,通过注入获取
属性 | 类型 | 必填 | 说明 |
---|---|---|---|
appid | string | 是 | 小程序 appId |
secret | string | 是 | 小程序 appSecret |
js_code | string | 是 | 登录时获取的 code,可通过wx.login获取 |
grant_type | string | 是 | 授权类型,此处只需填写 authorization_code |
判断是否登录成功
获取到openid之后,判断是否成功获取,若openid为null,就抛出自定义登陆失败异常
若不为null,则从数据库中获取该用户信息
判断是否为新用户
若user对象为null,则说明该用户为新用户,应向数据库中添加该用户信息
最后返回用户给控制层,控制层再获取到user中的字段数据,并封装在vo中返回给前端页面