AuthWeChatRequest.java 3.2 KB
Newer Older
1 2 3 4 5 6 7
package me.zhyd.oauth.request;

import cn.hutool.http.HttpRequest;
import cn.hutool.http.HttpResponse;
import com.alibaba.fastjson.JSONObject;
import me.zhyd.oauth.config.AuthConfig;
import me.zhyd.oauth.exception.AuthException;
智布道's avatar
智布道 已提交
8
import me.zhyd.oauth.model.*;
9 10 11 12 13
import me.zhyd.oauth.utils.UrlBuilder;

/**
 * 微信登录
 *
智布道's avatar
智布道 已提交
14 15 16
 * @author yangkai.shen (https://xkcoding.com)
 * @version 1.0
 * @since 1.8
17 18 19 20 21 22 23 24 25 26 27 28 29
 */
public class AuthWeChatRequest extends BaseAuthRequest {
    public AuthWeChatRequest(AuthConfig config) {
        super(config, AuthSource.WECHAT);
    }

    /**
     * 微信的特殊性,此时返回的信息同时包含 openid 和 access_token
     *
     * @param code 授权码
     * @return 所有信息
     */
    @Override
智布道's avatar
智布道 已提交
30
    protected AuthToken getAccessToken(String code) {
31
        String accessTokenUrl = UrlBuilder.getWeChatAccessTokenUrl(config.getClientId(), config.getClientSecret(), code);
32
        return this.getToken(accessTokenUrl);
33 34 35
    }

    @Override
智布道's avatar
智布道 已提交
36 37 38
    protected AuthUser getUserInfo(AuthToken authToken) {
        String accessToken = authToken.getAccessToken();
        String openId = authToken.getOpenId();
39

智布道's avatar
智布道 已提交
40
        HttpResponse response = HttpRequest.get(UrlBuilder.getWeChatUserInfoUrl(accessToken, openId)).execute();
41
        JSONObject object = JSONObject.parseObject(response.body());
42 43

        this.checkResponse(object);
44 45 46 47 48 49

        return AuthUser.builder()
                .username(object.getString("nickname"))
                .nickname(object.getString("nickname"))
                .avatar(object.getString("headimgurl"))
                .location(object.getString("country") + "-" + object.getString("province") + "-" + object.getString("city"))
50
                .uuid(openId)
51
                .gender(AuthUserGender.getRealGender(object.getString("sex")))
52
                .token(authToken)
53 54 55 56 57
                .source(AuthSource.WECHAT)
                .build();
    }

    @Override
58 59 60 61 62 63 64
    public AuthResponse refresh(AuthToken oldToken) {
        String refreshTokenUrl = UrlBuilder.getWeChatRefreshUrl(config.getClientId(), oldToken.getRefreshToken());
        return AuthResponse.builder()
                .code(ResponseStatus.SUCCESS.getCode())
                .data(this.getToken(refreshTokenUrl))
                .build();
    }
65

66 67 68 69 70 71
    /**
     * 检查响应内容是否正确
     *
     * @param object 请求响应内容
     */
    private void checkResponse(JSONObject object) {
72
        if (object.containsKey("errcode")) {
73
            throw new AuthException(object.getIntValue("errcode"), object.getString("errmsg"));
74
        }
75 76 77 78 79 80 81 82 83 84 85 86
    }
    /**
     * 获取token,适用于获取access_token和刷新token
     *
     * @param accessTokenUrl 实际请求token的地址
     * @return token对象
     */
    private AuthToken getToken(String accessTokenUrl) {
        HttpResponse response = HttpRequest.get(accessTokenUrl).execute();
        JSONObject object = JSONObject.parseObject(response.body());

        this.checkResponse(object);
87

88 89 90 91 92 93
        return AuthToken.builder()
                .accessToken(object.getString("access_token"))
                .refreshToken(object.getString("refresh_token"))
                .expireIn(object.getIntValue("expires_in"))
                .openId(object.getString("openid"))
                .build();
94 95
    }
}