AuthWeChatRequest.java 3.6 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.*;
10 11 12 13 14
import me.zhyd.oauth.utils.UrlBuilder;

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

    /**
     * 微信的特殊性,此时返回的信息同时包含 openid 和 access_token
     *
     * @param code 授权码
     * @return 所有信息
     */
    @Override
31 32
    protected AuthToken getAccessToken(AuthCallback authCallback) {
        String accessTokenUrl = UrlBuilder.getWeChatAccessTokenUrl(config.getClientId(), config.getClientSecret(), authCallback.getCode());
33
        return this.getToken(accessTokenUrl);
34 35 36
    }

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

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

        this.checkResponse(object);
45

智布道's avatar
智布道 已提交
46
        String location = String.format("%s-%s-%s", object.getString("country"), object.getString("province"), object.getString("city"));
47 48 49 50
        return AuthUser.builder()
                .username(object.getString("nickname"))
                .nickname(object.getString("nickname"))
                .avatar(object.getString("headimgurl"))
智布道's avatar
智布道 已提交
51
                .location(location)
52
                .uuid(openId)
53
                .gender(AuthUserGender.getRealGender(object.getString("sex")))
54
                .token(authToken)
55 56 57 58
                .source(AuthSource.WECHAT)
                .build();
    }

59 60 61 62 63 64 65 66 67 68
    /**
     * 返回认证url,可自行跳转页面
     *
     * @return 返回授权地址
     */
    @Override
    public String authorize() {
        return UrlBuilder.getWeChatAuthorizeUrl(config.getClientId(), config.getRedirectUri());
    }

69
    @Override
70 71 72 73 74 75 76
    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();
    }
77

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

89 90 91 92 93 94 95 96 97 98 99
    /**
     * 获取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);
100

101 102 103 104 105 106
        return AuthToken.builder()
                .accessToken(object.getString("access_token"))
                .refreshToken(object.getString("refresh_token"))
                .expireIn(object.getIntValue("expires_in"))
                .openId(object.getString("openid"))
                .build();
107 108
    }
}