0

我正在开发Spring MVC + Apache Oltu + Twitter示例。在此示例中,我通过在此处注册/创建应用程序client Id and Secrete从链接创建了一个:https ://apps.twitter.com/app/new。现在在 ClientId 和 Secrete 的帮助下,我想调用 Twitter 的 REST API。我还按照链接获取了scope https://developers.artsy.net/docs/authentication

我在我的应用程序中使用了以下参数:

AUTHORIZATION_URL = "https://api.twitter.com/oauth/authorize";
CLIENT_ID = "RSvE3qVXXXXXXXXXXXXXXXX";
CLIENT_SECRET = "nKEWRoOcXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
REDIRECT_URL = "http://localhost:8080/apache-oltu/twitter/redirect";
ACCESS_TOKEN_URL = "https://api.twitter.com/oauth/access_token";

出于安全目的,我在此处未正确显示clientIdsecrete现在,当我调用我的控制器时,我从 twitter 看到以下错误。

在此处输入图像描述

我的控制器实际上正在重定向到:

https://api.twitter.com/oauth/authorize?scope=offline_access&response_type=code&redirect_uri=
http%3A%2F%2Flocalhost%3A8080%2Fapache-oltu%2Ftwitter%2Fredirect&client_id=RSvE3qV6Hxfdgv39RJIjDvhhc

请指导/帮助我这里出了什么问题。有什么帮助吗?

scope=offline_access正确的吗?我分享了我的一些代码

controller:
@Controller
@RequestMapping("/twitter")
public class TwitterController {
    private static final Logger LOGGER = LoggerFactory.getLogger(TwitterController.class);

    private static final String AUTHORIZATION_URL = "https://api.twitter.com/oauth/authorize";
    private static final String CLIENT_ID = "RSvE3qVXXXXXXXXXXXXXXXXXXXXXX";
    private static final String CLIENT_SECRET = "nKEWRoXXXXXXXXXXXXXXXXXXXXXXXXXX";
    private static final String REDIRECT_URL = "http://localhost:8080/apache-oltu/twitter/redirect";
    private static final String ACCESS_TOKEN_URL = "https://api.twitter.com/oauth/access_token";

    @RequestMapping(value = "/auth", method = RequestMethod.GET)
    public String authenticate() throws OAuthSystemException {
        OAuthClientRequest request = OAuthClientRequest
                .authorizationLocation(AUTHORIZATION_URL)
                .setClientId(CLIENT_ID)
                .setRedirectURI(REDIRECT_URL)
                .setResponseType("code")
                .setScope("offline_access")
                .buildQueryMessage();

        System.out.println("REDIRECT TO: "+request.getLocationUri());
        return "redirect:" + request.getLocationUri();
    }

    @RequestMapping(value = "/redirect", method = RequestMethod.GET)
    public HttpEntity<String> redirect(@RequestParam(value = "code", required = false) String code) throws OAuthSystemException, OAuthProblemException {
        String value = "UNKNOWN";

        if (code != null && code.length() > 0) {
            System.out.println("Received CODE: "+code);
            getAccessToken(code);
            value = code;
        }

        return new ResponseEntity<String>(value,HttpStatus.OK);
    }
..........................
.........................
}

有什么帮助吗?

4

1 回答 1

0

请参阅此文档。 https://dev.twitter.com/web/sign-in/implementing

我相信您需要在调用授权 URL ( https://api.twitter.com/oauth/authorize ) 之前调用请求令牌 URL ( https://api.twitter.com/oauth/request_token ) 以获取 oauth_token 。

这是额外的步骤和其他 OAuth 提供者......

于 2017-05-18T04:28:54.273 回答