AuthWeChatRequest.java 3.7 KB
Newer Older
1 2 3 4 5 6
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;
7
import me.zhyd.oauth.config.AuthSource;
8
import me.zhyd.oauth.exception.AuthException;
9
import me.zhyd.oauth.model.*;
智布道's avatar
智布道 已提交
10
import me.zhyd.oauth.url.AuthWechatUrlBuilder;
11
import me.zhyd.oauth.url.entity.AuthUserInfoEntity;
12 13 14 15

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

    /**
     * 微信的特殊性,此时返回的信息同时包含 openid 和 access_token
     *
智布道's avatar
智布道 已提交
28
     * @param authCallback 回调返回的参数
29 30 31
     * @return 所有信息
     */
    @Override
32
    protected AuthToken getAccessToken(AuthCallback authCallback) {
智布道's avatar
智布道 已提交
33
        String accessTokenUrl = this.urlBuilder.getAccessTokenUrl(authCallback.getCode());
34
        return this.getToken(accessTokenUrl);
35 36 37
    }

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

42 43 44 45
        HttpResponse response = HttpRequest.get(this.urlBuilder.getUserInfoUrl(AuthUserInfoEntity.builder()
                .accessToken(accessToken)
                .openId(openId)
                .build())).execute();
46
        JSONObject object = JSONObject.parseObject(response.body());
47 48

        this.checkResponse(object);
49

智布道's avatar
智布道 已提交
50
        String location = String.format("%s-%s-%s", object.getString("country"), object.getString("province"), object.getString("city"));
51 52 53 54 55

        if (object.containsKey("unionid")){
            authToken.setUnionId(object.getString("unionid"));
        }

56 57 58 59
        return AuthUser.builder()
                .username(object.getString("nickname"))
                .nickname(object.getString("nickname"))
                .avatar(object.getString("headimgurl"))
智布道's avatar
智布道 已提交
60
                .location(location)
61
                .uuid(openId)
62
                .gender(AuthUserGender.getRealGender(object.getString("sex")))
63
                .token(authToken)
64 65 66 67 68
                .source(AuthSource.WECHAT)
                .build();
    }

    @Override
69
    public AuthResponse refresh(AuthToken oldToken) {
智布道's avatar
智布道 已提交
70
        String refreshTokenUrl = this.urlBuilder.getRefreshUrl(oldToken.getRefreshToken());
71
        return AuthResponse.builder()
智布道's avatar
智布道 已提交
72
                .code(AuthResponseStatus.SUCCESS.getCode())
73 74 75
                .data(this.getToken(refreshTokenUrl))
                .build();
    }
76

77 78 79 80 81 82
    /**
     * 检查响应内容是否正确
     *
     * @param object 请求响应内容
     */
    private void checkResponse(JSONObject object) {
83
        if (object.containsKey("errcode")) {
84
            throw new AuthException(object.getIntValue("errcode"), object.getString("errmsg"));
85
        }
86
    }
智布道's avatar
智布道 已提交
87

88 89 90 91 92 93 94 95
    /**
     * 获取token,适用于获取access_token和刷新token
     *
     * @param accessTokenUrl 实际请求token的地址
     * @return token对象
     */
    private AuthToken getToken(String accessTokenUrl) {
        HttpResponse response = HttpRequest.get(accessTokenUrl).execute();
智布道's avatar
智布道 已提交
96
        JSONObject accessTokenObject = JSONObject.parseObject(response.body());
97

智布道's avatar
智布道 已提交
98
        this.checkResponse(accessTokenObject);
99

100
        return AuthToken.builder()
智布道's avatar
智布道 已提交
101 102 103 104
                .accessToken(accessTokenObject.getString("access_token"))
                .refreshToken(accessTokenObject.getString("refresh_token"))
                .expireIn(accessTokenObject.getIntValue("expires_in"))
                .openId(accessTokenObject.getString("openid"))
105
                .build();
106 107
    }
}