Pregunta

Estoy tratando de obtener el token de acceso de un usuario usando Twitter4J en mi proyecto Appengine. Mi código está abajo

    HttpSession session = req.getSession();
    String tokenCopy = (String) session
            .getAttribute(Constants.TOKEN_SESSION_KEY);
    String tokenSecretCopy = (String) session
            .getAttribute(Constants.TOKENSECRET_SESSION_KEY);

    String oauth_token = req.getParameter("oauth_token");
    //The above is the same as the tokenCopy, verified by printing.
    String oauth_verifier = req.getParameter("oauth_verifier");

    Twitter twitter = new TwitterFactory().getInstance();
    twitter.setOAuthConsumer(Constants.CONSUMER_KEY,
            Constants.CONSUMER_SECRET);

    String extraHTML = "NOTHING\n";

    try {
        AccessToken accessToken;
        accessToken = twitter
                .getOAuthAccessToken(tokenCopy, oauth_verifier);
        // accessToken = twitter.getOAuthAccessToken(oauth_verifier);
        // accessToken = twitter.getOAuthAccessToken();

        String accessTokenStr = accessToken.getToken();
        String accessTokenSecret = accessToken.getTokenSecret();
        extraHTML = "<p>accessToken = " + accessTokenStr
                + ", accessTokenSecret = " + accessTokenSecret + "</p>\n";

        // TODO latertwitter.setOAuthAccessToken(accessToken);
    } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
        extraHTML = "<pre>" + e.getMessage() + "</pre>\n";
    }

Lamentablemente, cuando se ejecuta mi código, siempre tengo la excepción

401:Authentication credentials (https://dev.twitter.com/docs/auth) were missing or
incorrect. Ensure that you have set valid conumer key/secret, access token/secret,
and the system clock in in sync.

conozco mi CONSUMER_KEY y CONSUMER_SECRET son correctos (los usé para crear la URL de autenticación de Twitter y eso funciona bien). ¿Que me estoy perdiendo aqui? ¿Debería pasar algo más a la llamada a getOAuthAccessToken() ?

Gracias.

¿Fue útil?

Solución

Estoy usando RequestToken objeto, en lugar de String, todo lo demás se ve igual.

Quiero decir que cuando estoy preparando URL de autenticación, lo estoy haciendo:

RequestToken requestToken = twitter.getOAuthRequestToken(callbackUrl);
session.setAttribute(Constants.TOKEN_SESSION_KEY, requestToken);

y en lugar de la línea #2 de su código será:

RequestToken tokenCopy = (RequestToken) session.getAttribute(Constants.TOKEN_SESSION_KEY);

Todo lo demás se ve correcto.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top