Apache Oltu OAuthClient.accessToken()因超时而失败

时间:2015-10-19 11:15:14

标签: java oauth openid-connect oltu

我尝试使用Google OpenID登录用户。

当我尝试验证用户时,我总是在尝试检索AccessToken时遇到超时。

public class TestRun {
    public static void main(String args[]) throws OAuthSystemException, OAuthProblemException {
        OAuthClientRequest request = OAuthClientRequest
                .tokenProvider(OAuthProviderType.GOOGLE)
                .setGrantType(GrantType.AUTHORIZATION_CODE)
                .setCode("")
                .setRedirectURI(Env.REST_API_LOCATION+"/login")
                .setClientId(Env.CLIENT_ID)
                .setClientSecret(Env.CLIENT_SECRET)
                .buildQueryMessage();

        OAuthClient oac = new OAuthClient(new URLConnectionClient());
        OAuthAccessTokenResponse response = oac.accessToken(request);
        System.out.println(response.getAccessToken());
        System.out.println(response.getExpiresIn());
    }
}

oac.accessToken(请求)被调用时,我总是遇到 ConnectException (超时),并且不再获取有关'发生了。

1 个答案:

答案 0 :(得分:1)

所以,问题很简单。运行我的软件的系统可以从Internet访问,但出站流量被强制使用代理。由于代理不是透明的,我必须编写自己的 HttpClient 实现,它能够处理代理并用它替换 URLConnectionClient