AuthWeChatRequest.java 3.3 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 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
import me.zhyd.oauth.utils.UrlBuilder;

/**
 * <p>
 * 微信登录
 * </p>
 *
 * @package: me.zhyd.oauth.request
 * @description: 微信登录
 * @author: yangkai.shen
 * @date: Created in 2019-05-17 11:11
 * @copyright: Copyright (c) 2019
 * @version: V1.0
 * @modified: yangkai.shen
 */
public class AuthWeChatRequest extends BaseAuthRequest {
    public AuthWeChatRequest(AuthConfig config) {
        super(config, AuthSource.WECHAT);
    }

    /**
     * 微信的特殊性,此时返回的信息同时包含 openid 和 access_token
     *
     * @param code 授权码
     * @return 所有信息
     */
    @Override
智布道's avatar
智布道 已提交
36
    protected AuthToken getAccessToken(String code) {
37 38 39 40 41 42 43
        String accessTokenUrl = UrlBuilder.getWeChatAccessTokenUrl(config.getClientId(), config.getClientSecret(), code);
        HttpResponse response = HttpRequest.get(accessTokenUrl).execute();
        JSONObject accessTokenObject = JSONObject.parseObject(response.body());
        if (!accessTokenObject.containsKey("access_token") || !accessTokenObject.containsKey("openid") || !accessTokenObject
                .containsKey("refresh_token")) {
            throw new AuthException("Unable to get access_token or openid or refresh_token from wechat using code [" + code + "]");
        }
智布道's avatar
智布道 已提交
44 45 46 47 48 49
        JSONObject object = JSONObject.parseObject(response.body());
        return AuthToken.builder()
                .accessToken(object.getString("access_token"))
                .refreshToken(object.getString("refresh_token"))
                .openId(object.getString("openid"))
                .build();
50 51 52
    }

    @Override
智布道's avatar
智布道 已提交
53 54 55
    protected AuthUser getUserInfo(AuthToken authToken) {
        String accessToken = authToken.getAccessToken();
        String openId = authToken.getOpenId();
56

智布道's avatar
智布道 已提交
57
        HttpResponse response = HttpRequest.get(UrlBuilder.getWeChatUserInfoUrl(accessToken, openId)).execute();
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
        JSONObject object = JSONObject.parseObject(response.body());
        if (object.containsKey("errcode")) {
            throw new AuthException(object.getString("errmsg"));
        }

        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"))
                .gender(AuthUserGender.getRealGender(object.getString("sex")))
                .accessToken(accessToken)
                .source(AuthSource.WECHAT)
                .build();
    }

    @Override
智布道's avatar
智布道 已提交
75 76
    public AuthResponse refresh(AuthToken authToken) {
        String refreshToken = authToken.getRefreshToken();
77 78 79 80 81 82 83 84 85 86 87
        HttpResponse response = HttpRequest.get(UrlBuilder.getWeChatRefreshUrl(config.getClientId(), refreshToken))
                .execute();

        JSONObject object = JSONObject.parseObject(response.body());
        if (object.containsKey("errcode")) {
            throw new AuthException(object.getString("errmsg"));
        }

        return AuthResponse.builder().data(object).build();
    }
}