AuthQqRequest.java 4.7 KB
Newer Older
1 2
package me.zhyd.oauth.request;

3
import cn.hutool.core.util.StrUtil;
4 5 6 7
import cn.hutool.http.HttpRequest;
import cn.hutool.http.HttpResponse;
import com.alibaba.fastjson.JSONObject;
import me.zhyd.oauth.config.AuthConfig;
8
import me.zhyd.oauth.config.AuthSource;
9
import me.zhyd.oauth.exception.AuthException;
10
import me.zhyd.oauth.model.AuthCallback;
11
import me.zhyd.oauth.model.AuthToken;
12 13
import me.zhyd.oauth.model.AuthUser;
import me.zhyd.oauth.model.AuthUserGender;
14 15 16 17
import me.zhyd.oauth.url.QqUrlBuilder;
import me.zhyd.oauth.url.entity.AuthAccessTokenEntity;
import me.zhyd.oauth.url.entity.AuthAuthorizeEntity;
import me.zhyd.oauth.url.entity.AuthUserInfoEntity;
18
import me.zhyd.oauth.utils.GlobalAuthUtil;
19 20
import me.zhyd.oauth.utils.StringUtils;

21 22
import java.util.Map;

23 24 25 26
/**
 * qq登录
 *
 * @author yadong.zhang (yadong.zhang0415(a)gmail.com)
27
 * @author yangkai.shen (https://xkcoding.com)
28 29 30 31 32
 * @version 1.0
 * @since 1.8
 */
public class AuthQqRequest extends BaseAuthRequest {
    public AuthQqRequest(AuthConfig config) {
33
        super(config, AuthSource.QQ, new QqUrlBuilder());
34 35 36
    }

    @Override
37
    protected AuthToken getAccessToken(AuthCallback authCallback) {
38 39 40 41
        String accessTokenUrl = this.urlBuilder.getAccessTokenUrl(AuthAccessTokenEntity.builder()
                .config(config)
                .code(authCallback.getCode())
                .build());
42 43
        HttpResponse response = HttpRequest.get(accessTokenUrl).execute();
        Map<String, String> accessTokenObject = GlobalAuthUtil.parseStringToMap(response.body());
44
        if (!accessTokenObject.containsKey("access_token")) {
45
            throw new AuthException("Unable to get token from qq using code [" + authCallback.getCode() + "]");
46
        }
47
        return AuthToken.builder()
48 49 50
                .accessToken(accessTokenObject.get("access_token"))
                .expireIn(Integer.valueOf(accessTokenObject.get("expires_in")))
                .refreshToken(accessTokenObject.get("refresh_token"))
51
                .build();
52 53 54
    }

    @Override
55 56
    protected AuthUser getUserInfo(AuthToken authToken) {
        String accessToken = authToken.getAccessToken();
智布道's avatar
智布道 已提交
57
        String openId = this.getOpenId(authToken);
58 59 60 61 62
        HttpResponse response = HttpRequest.get(this.urlBuilder.getUserInfoUrl(AuthUserInfoEntity.builder()
                .clientId(config.getClientId())
                .accessToken(accessToken)
                .openId(openId)
                .build()))
63
                .execute();
64 65 66 67 68 69 70 71
        JSONObject object = JSONObject.parseObject(response.body());
        if (object.getIntValue("ret") != 0) {
            throw new AuthException(object.getString("msg"));
        }
        String avatar = object.getString("figureurl_qq_2");
        if (StringUtils.isEmpty(avatar)) {
            avatar = object.getString("figureurl_qq_1");
        }
智布道's avatar
智布道 已提交
72 73

        String location = String.format("%s-%s", object.getString("province"), object.getString("city"));
74 75 76 77
        return AuthUser.builder()
                .username(object.getString("nickname"))
                .nickname(object.getString("nickname"))
                .avatar(avatar)
智布道's avatar
智布道 已提交
78
                .location(location)
79
                .uuid(openId)
80
                .gender(AuthUserGender.getRealGender(object.getString("gender")))
81
                .token(authToken)
82 83 84 85
                .source(AuthSource.QQ)
                .build();
    }

86 87 88 89 90 91 92
    /**
     * 返回认证url,可自行跳转页面
     *
     * @return 返回授权地址
     */
    @Override
    public String authorize() {
93 94 95
        return this.urlBuilder.getAuthorizeUrl(AuthAuthorizeEntity.builder()
                .config(config)
                .build());
96 97
    }

智布道's avatar
智布道 已提交
98 99
    private String getOpenId(AuthToken authToken) {
        String accessToken = authToken.getAccessToken();
100
        HttpResponse response = HttpRequest.get(this.urlBuilder.getOpenIdUrl(accessToken, config.isUnionId())).execute();
101
        if (response.isOk()) {
102 103 104 105 106
            String body = response.body();
            String removePrefix = StrUtil.replace(body, "callback(", "");
            String removeSuffix = StrUtil.replace(removePrefix, ");", "");
            String openId = StrUtil.trim(removeSuffix);
            JSONObject object = JSONObject.parseObject(openId);
智布道's avatar
智布道 已提交
107 108
            if (object.containsKey("error")) {
                throw new AuthException(object.get("error") + ":" + object.get("error_description"));
109
            }
智布道's avatar
智布道 已提交
110
            authToken.setOpenId(object.getString("openid"));
111 112 113
            if (object.containsKey("unionid")) {
                authToken.setUnionId(object.getString("unionid"));
            }
114
            return StringUtils.isEmpty(authToken.getUnionId()) ? authToken.getOpenId() : authToken.getUnionId();
115
        }
S
skqing 已提交
116 117

        throw new AuthException("request error");
118 119
    }
}