AuthAlipayRequest.java 3.9 KB
Newer Older
1 2 3 4 5 6 7 8 9 10
package me.zhyd.oauth.request;

import com.alipay.api.AlipayApiException;
import com.alipay.api.AlipayClient;
import com.alipay.api.DefaultAlipayClient;
import com.alipay.api.request.AlipaySystemOauthTokenRequest;
import com.alipay.api.request.AlipayUserInfoShareRequest;
import com.alipay.api.response.AlipaySystemOauthTokenResponse;
import com.alipay.api.response.AlipayUserInfoShareResponse;
import me.zhyd.oauth.config.AuthConfig;
11
import me.zhyd.oauth.config.AuthSource;
智布道's avatar
智布道 已提交
12
import me.zhyd.oauth.enums.AuthUserGender;
13
import me.zhyd.oauth.exception.AuthException;
14
import me.zhyd.oauth.model.AuthCallback;
15
import me.zhyd.oauth.model.AuthToken;
16 17
import me.zhyd.oauth.model.AuthUser;
import me.zhyd.oauth.utils.StringUtils;
不合群的混子's avatar
不合群的混子 已提交
18
import me.zhyd.oauth.utils.UrlBuilder;
19 20

/**
21 22
 * 支付宝登录
 *
23 24 25
 * @author yadong.zhang (yadong.zhang0415(a)gmail.com)
 * @since 1.8
 */
智布道's avatar
智布道 已提交
26
public class AuthAlipayRequest extends AuthDefaultRequest {
27 28 29 30

    private AlipayClient alipayClient;

    public AuthAlipayRequest(AuthConfig config) {
不合群的混子's avatar
不合群的混子 已提交
31
        super(config, AuthSource.ALIPAY);
32
        this.alipayClient = new DefaultAlipayClient(AuthSource.ALIPAY.accessToken(), config.getClientId(), config.getClientSecret(), "json", "UTF-8", config
不合群的混子's avatar
不合群的混子 已提交
33
            .getAlipayPublicKey(), "RSA2");
34 35 36
    }

    @Override
37
    protected AuthToken getAccessToken(AuthCallback authCallback) {
38 39
        AlipaySystemOauthTokenRequest request = new AlipaySystemOauthTokenRequest();
        request.setGrantType("authorization_code");
智布道's avatar
智布道 已提交
40
        request.setCode(authCallback.getAuth_code());
41 42 43 44
        AlipaySystemOauthTokenResponse response = null;
        try {
            response = this.alipayClient.execute(request);
        } catch (Exception e) {
智布道's avatar
智布道 已提交
45
            throw new AuthException(e);
46 47 48 49
        }
        if (!response.isSuccess()) {
            throw new AuthException(response.getSubMsg());
        }
50
        return AuthToken.builder()
不合群的混子's avatar
不合群的混子 已提交
51 52 53 54 55
            .accessToken(response.getAccessToken())
            .uid(response.getUserId())
            .expireIn(Integer.parseInt(response.getExpiresIn()))
            .refreshToken(response.getRefreshToken())
            .build();
56 57 58
    }

    @Override
59 60
    protected AuthUser getUserInfo(AuthToken authToken) {
        String accessToken = authToken.getAccessToken();
61 62 63 64 65 66 67 68 69 70
        AlipayUserInfoShareRequest request = new AlipayUserInfoShareRequest();
        AlipayUserInfoShareResponse response = null;
        try {
            response = this.alipayClient.execute(request, accessToken);
        } catch (AlipayApiException e) {
            throw new AuthException(e.getErrMsg(), e);
        }
        if (!response.isSuccess()) {
            throw new AuthException(response.getSubMsg());
        }
智布道's avatar
智布道 已提交
71

不合群的混子's avatar
不合群的混子 已提交
72
        String province = response.getProvince(), city = response.getCity();
智布道's avatar
智布道 已提交
73 74
        String location = String.format("%s %s", StringUtils.isEmpty(province) ? "" : province, StringUtils.isEmpty(city) ? "" : city);

75
        return AuthUser.builder()
不合群的混子's avatar
不合群的混子 已提交
76 77 78 79 80 81 82
            .uuid(response.getUserId())
            .username(StringUtils.isEmpty(response.getUserName()) ? response.getNickName() : response.getUserName())
            .nickname(response.getNickName())
            .avatar(response.getAvatar())
            .location(location)
            .gender(AuthUserGender.getRealGender(response.getGender()))
            .token(authToken)
83
            .source(source)
不合群的混子's avatar
不合群的混子 已提交
84 85 86 87
            .build();
    }

    /**
88
     * 返回带{@code state}参数的认证url,授权回调时会带上这个{@code state}
不合群的混子's avatar
不合群的混子 已提交
89
     *
90
     * @param state state 验证授权流程的参数,可以防止csrf
不合群的混子's avatar
不合群的混子 已提交
91
     * @return 返回授权地址
智布道's avatar
智布道 已提交
92
     * @since 1.9.3
不合群的混子's avatar
不合群的混子 已提交
93 94
     */
    @Override
95
    public String authorize(String state) {
不合群的混子's avatar
不合群的混子 已提交
96 97 98 99
        return UrlBuilder.fromBaseUrl(source.authorize())
            .queryParam("app_id", config.getClientId())
            .queryParam("scope", "auth_user")
            .queryParam("redirect_uri", config.getRedirectUri())
100
            .queryParam("state", getRealState(state))
不合群的混子's avatar
不合群的混子 已提交
101
            .build();
102 103
    }
}