Pular para o conteúdo principal

Uma forma de usar Twitter4J com OAuth

Já faz bastante tempo que escrevi um post sobre como enviar tweets através de uma aplicação Java usando a biblioteca Twitter4J e de lá para cá tivemos algumas atualizações e uma delas foi o fato de não ser mais possível usar autenticação básica como eu coloquei de exemplo.

Hoje eu vi a Yara citar no Twitter este meu post como exemplo de uso e responderam a ela que não funcionava mais assim, então resolvi pesquisar e colocar aqui no blog a solução que encontrei.

Buscando na internet, encontrei rapidamente este artigo em inglês no blog da EMC, e como está bem explicado, peço licença ao autor Nileesha Bojjawar para colocar aqui traduzido para o português e compartilhar com vocês.

Neste texto, além de mostrar como autenticar usando OAuth, também dá a dica de como registrar uma aplicação para editar a timeline de uma conta do Twitter. Vamos ao passo a passo então:

"...

Crie uma conta no Twitter
Crie a conta do Twitter que você quer usar da sua aplicação. No exemplo eu usei uma conta de teste que eu criei.

Registre a aplicação
Faça login no Twitter e registre uma nova aplicação com twitter neste link.

Assim que tiver registrado a aplicação, você pode editá-la e vê-la da sua conta do Twitter, através da página settings -> connections.

Por favor, note: para que este exemplo funcione, você tem que selecionar Application Type como “Client”. Application Type como “Browser” espera que você tenha um website com um servlet call-back para o qual o Twitter possa enviar o token de acesso.

Obtenha ConsumerKey e ConsumerSecret
Você receberá a ConsumerKey e ConsumerSecret nesta página. Você pode armazenar isto de forma persistente, para simplicidade, você pode usar um arquivo de properties.

Obtenha Access Token e Access Secret
Para usar OAuth a aplicação deve usar o login do Twitter usando uma Access Token. Obter a access token e a token secret é um processo que se faz uma única vez para cada ConsumerKey e ConsumerSecret e todos estes valores podem ser armazenados juntos num mesmo arquivo.
A maioria dos exemplos que encontramos por aí usam um call-back Servlet/URL para conseguir o token. Eu pessoalmente acho que isto é demais, criar um call-back Servlet só para obter os Access Tokens. É mais fácil obter isto usando uma aplicação cliente e armazená-los. O código cliente de exemplo está aqui:
import java.io.BufferedReader;
import java.io.InputStreamReader;
import twitter4j.Status;
import twitter4j.Twitter;
import twitter4j.TwitterException;
import twitter4j.TwitterFactory;
import twitter4j.http.AccessToken;
import twitter4j.http.RequestToken;
public class OAuthSetup {
  /**
   * @param args
   */
  public static void main(String args[]) throws Exception {
      // The factory instance is re-useable and thread safe.

Twitter twitter = new TwitterFactory().getInstance();

//insert the appropriate consumer key and consumer secret here

      twitter.setOAuthConsumer("ZDuEJCn23jw3NuFcElaqw",
          "OkhinXH6EaymMUzlfbq0xWrablNBkUwfz7eLDPxmwk");
      RequestToken requestToken = twitter.getOAuthRequestToken();
      AccessToken accessToken = null;
      BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
      while (null == accessToken) {
        System.out.println("Open the following URL and grant access to your account:");
        System.out.println(requestToken.getAuthorizationURL());
        System.out.print("Enter the PIN(if aviailable) or just hit enter.[PIN]:");
        String pin = br.readLine();
        try{
           if(pin.length() > 0){
             accessToken = twitter.getOAuthAccessToken(requestToken, pin);
           }else{
             accessToken = twitter.getOAuthAccessToken();
           }
        } catch (TwitterException te) {
          if(401 == te.getStatusCode()){
            System.out.println("Unable to get the access token.");
          }else{
            te.printStackTrace();
          }
        }
      }
      //persist to the accessToken for future reference.
      System.out.println(twitter.verifyCredentials().getId());
      System.out.println("token : " + accessToken.getToken());
      System.out.println("tokenSecret : " + accessToken.getTokenSecret());
      //storeAccessToken(twitter.verifyCredentials().getId() , accessToken);
      Status status = twitter.updateStatus(args[0]);
      System.out.println("Successfully updated the status to [" + status.getText() + "].");
      System.exit(0);
    }
}
Quando você executa este código, com as ConsumerKey e ConsumerSecret corretas, você receberá uma Authorisation URL na console, como abaixo:

Open the following URL and grant access to your account:
https://twitter.com/oauth/authorize?oauth_token=trVYjyf0r1jeuildLedHSSQMKmdKXdDEfI5ffiuQmcM
Enter the PIN(if aviailable) or just hit enter.[PIN]:

Pegue esta URL e cole-a no browser e permita o acesso.Em seguida, o Twitter te dará um número de pin, que você deve copiar e retornar para sua aplicação e digitar no prompt.

Open the following URL and grant access to your account:
https://twitter.com/oauth/authorize?oauth_token=trVYjyf0r1jeuildLedHSSQMKmdKXdDEfI5ffiuQmcM
Enter the PIN(if aviailable) or just hit enter.[PIN]:6829121

A aplicação vai então gerar seu token e tokenSecret como a seguir:

Open the following URL and grant access to your account:
https://twitter.com/oauth/authorize?oauth_token=trVYjyf0r1jeuildLedHSSQMKmdKXdDEfI5ffiuQmcM
Enter the PIN(if aviailable) or just hit enter.[PIN]:6829121
119319081
token : 119319081-Q3l4OThX7LDHkd6voqI6sZ1oDCJsvcCxavXhVZjK
tokenSecret : 6ypMga7IL8fR7zH2BBLBdIt5VlYuCLb2d1Orco1bqI

Persista estes dados em algum arquivo properties ( como você persiste e assegura isto é sua escolha )

Tudo que este código faz é
  • Criar uma instância da classe Twitter
  • Setar a OAuth Consumer nesta instância
  • Gerar uma authorisation URL que você deve colar no browser e permitir acesso da sua conta do twitter para a aplicação
  • Isto te dará um número de pin, que você tem que digitar no código cliente em execução
  • Então vai gerar suas access token e access token secret que você pode ou não persistir
Faça login pela a aplicação registrada e envie seus tweets
A última coisa a fazer é usar este OAuth Login para enviar tweets da sua aplicação. A instância do Twitter para enviar tweets pode ser criada como segue:
private Twitter twitter;
twitter = new TwitterFactory().getInstance();
twitter.setOAuthConsumer(consumerKey, consumerSecret);
AccessToken accessToken = new AccessToken(twitterToken, twitterTokenSecret);
twitter.setOAuthAccessToken(accessToken);

Espero que seja útil.

..."

Bom, esta foi a tradução que fiz, espero que tenha ficado razoável, que tenha dado para entender pelo menos.
Não se esqueça que precisa ter o Twitter4J no classpath para funcionar, é só baixar o jar neste link.
Para complementar, vou colocar abaixo a classe completa de teste que usei como se fosse a aplicação que registrei na minha conta do Twitter:

import twitter4j.Twitter;
import twitter4j.TwitterException;
import twitter4j.TwitterFactory;
import twitter4j.http.AccessToken;

public class TwitterTester {

public static void main (String[] args){
String consumerKey = "ZDuEJCn23jw3NuFcElaqw";
String consumerSecret = "OkhinXH6EaymMUzlfbq0xWrablNBkUwfz7eLDPxmwk";
String twitterToken = "119319081-Q3l4OThX7LDHkd6voqI6sZ1oDCJsvcCxavXhVZjK";
String twitterTokenSecret = "6ypMga7IL8fR7zH2BBLBdIt5VlYuCLb2d1Orco1bqI";

Twitter twitter = new TwitterFactory().getInstance();
twitter.setOAuthConsumer(consumerKey, consumerSecret);
AccessToken accessToken = new AccessToken(twitterToken, twitterTokenSecret);
twitter.setOAuthAccessToken(accessToken);

try{
twitter.updateStatus("Testando...");
System.out.println("Tweet enviado!");
} catch(TwitterException e){
System.out.println("Erro ao enviar o tweet");
}
}

}


[]s

Ana Abrantes
twitter.com/anabrant

Comentários

Ana,

excelente post.

Tem algum lugar que podemos baixar os fontes do seu exemplo?

Abs!
Ana Abrantes disse…
Jeff,

A classe para conseguir os tokens é esta que coloquei aí, a OAuthSetup, depois é só usar na sua aplicação o segundo trecho de código.

Só faltou eu mencionar que precisa ter o Twitter4J no classpath para funcionar, é só baixar o jar neste link: http://twitter4j.org/en/index.html#download

Mais tarde, vou colocar o código da classe que usei para testar, acho que fica mais claro, né?

[]s

Ana
Alex Coqueiro disse…
Muito legal Ana.

Acabei de testar e funcionou. ótima iniciativa.
Unknown disse…
Muito Bom Ana.
Testei aqui, funcionou também!
Ótimo post!
[]'ss

@JeanDonato
Unknown disse…
Show de bola...resolveu o meu problema do lance de como persistir a chave do Token :D

Postagens mais visitadas deste blog

10 reasons why we love JSF

1. One-slide technology: it's so simple that I can explain basic JSF with one slide. 2. Easy to extend: components, listeners, render kit, Events, Controller, etc. 3. Real-world adoption: JBoss, Exadel, Oracle, IBM, ... 4. Architecture model: you can choose between more than 100 different architecture. 5. Open-mind community: using JSF you are going to meet very interesting people. 6. We are using JSF the last 5 years and we found very good market for JSF in Brazil 7. Progress: look to JSf 1.1 to JSF 1.2, JSF 1.2 to JSF 2.0. People are working really hard! 8. Many professionals now available 9. It's a standard. It's JCP. Before complain, report and help! 10. Ed Burns, spec leader, is an old Globalcode community friend! EXTRA: My wife is specialist in JSF. She's my F1 for JSF :) Nice job JSF community! -Vinicius Senger

O que é Lógica de programação?

Este é o segundo de uma série de posts voltados aos leitores do blog que estão dando início à carreira de desenvolvimento de software. O assunto de hoje é a lógica de programação. Para ler antes: Entendendo como funciona a programação de computadores: linguagens de programação, lógica, banco de dados A lógica de programação é um pré-requisito para quem quer se tornar um desenvolvedor de software, independente da linguagem de programação que se pretende utilizar. Mas o que é de fato a Lógica de Programação e como saber se eu tenho esse pré-requisito? A lógica de programação nada mais é do que a organização coerente das instruções do programa para que seu objetivo seja alcançado. Para criar essa organização, instruções simples do programa, como mudar o valor de uma variável ou desenhar uma imagem na tela do computador, são interconectadas a estruturas lógicas que guiam o fluxo da execução do programa. Isso é muito próximo ao que usamos em nosso cotidiano para realizar atividad...

Alguma certificação Java nos seus planos em 2010 ?

A discussão sobre certificações é super polêmica, alguns acham muito importante, outros acham totalmente insignificante. Eu particularmente acho que é uma meta de aprendizado, que nos força a aprender bem detalhadamente uma tecnologia. É claro que é "burlável" quero dizer, todo mundo conhece alguém que é certificado e "não sabe nada". Mas, evidentemente quando você se prepara, estuda, vai aprender muitas coisas novas e solidificar ainda mais seu conhecimento. Eu sempre fui muito "orientada" por deadlines... estas metas nos obrigam a encaixar algumas horas de estudo nesta vida tão corrida. E o inicio do ano é muito bom para estas iniciativas, porque estamos um pouco mais descansados, com aquele espírito de inicio de ano. Imagine chegar em março e já ter cumprido uma das metas de final de ano, e estar com a certificação "tirada" ? Não acho que precisa ser um caçador de certificações, e tentar tirar todas as certificações possíveis, mas acho ...

Facelets uma forma mais ágil para construção de telas – Parte I

A construção de telas ou camada de apresentação em um sistema MVC seja web ou desktop é uma tarefa complexa e de extrema importância. Nesse post vou comentar e mostrar algum exemplo do Facelets como solução para os desafios existentes nessa etapa especificamente para web. Com a web cada vez mais presente em nosso dia-a-dia, um fato é que com isso nossos usuários tornam-se mais exigentes em relação a usabilidade, agilidade, performance ou de uma forma bem resumida “o usuário espera uma navegação simples e agradável aonde uma determinado tarefa possa ser concluída em poucos passos e em um curto espaço de tempo”. Atender as expectativas em relação ao que o usuário espera com o que realmente ele precisa, definir uma estrutura flexível a mudanças sem engessar o desenvolvimento, acessibilidade, portabilidade em múltiplos navegadores, tudo isso e muito mais, num prazo que quase sempre é apertado. Um outro ponto fundamental é manter o time motivado e produtivo em um ambiente que favoreça a...

TDC BUSINESS, chega a São Paulo com novas trilhas de Inteligência Artificial e Inovação

Maior conferência de profissionais de tecnologia do Brasil abordará temas em alta no momento como, por exemplo, Inteligência Artificial, Segurança, Ciência de Dados e Inovação O TDC BUSINESS, a 17° edição do The Developer's Conference na cidade de São Paulo, que acontece entre os dias 19 e 21 de Setembro, reunirá profissionais e especialistas da área para troca de experiência, compartilhamento de conteúdos e networking. Com o tema central: “Tecnologia para negócios transformadores”, o evento será totalmente híbrido, ocorrendo presencialmente no espaço Pro Magno, e com transmissão simultânea e atividades de network pela internet. A expectativa é reunir mais de 14.000 pessoas, somando a participação presencial e online.   Segundo Yara Mascarenhas, Fundadora e Host do Evento, “nosso objetivo com o TDC é inspirar a colaboração entre os profissionais e empresas para construir uma nova realidade para o mercado de TI.  Vamos juntar tecnologia e negócios com as trilhas técnicas...

JavaMail: Enviando mensagem HTML com anexos

Introdução Depois do post "JavaMail: Enviando e-mail com Java" , que apresentava como enviar um e-mail com Java, resolvi complementar a assunto apresentando como enviar uma mensagem formatada, em HTML , e também como realizar o envio de anexos. Bibliotecas Além da biblioteca JavaMail, veja mais no post anterior , é necessário incluir o JavaBeans Activation Framework (JAF), apenas se a versão utilizada for anterior ao JSE 6.0 , que já tem o JAF incluso. O JAF está disponível em http://www.oracle.com/technetwork/java/javase/downloads/index-135046.html , e neste download encontramos, alguns exemplos na pasta demo , documentação, incluindo javadocs, na pasta docs e a biblioteca activation.jar , que deve ser acrescentada no classpath da aplicação para versões anteriores ao JSE 6.0. Exemplo Primeiramente devemos realizar a configuração da javax.mail.Session e da javax.mail.internet.MimeMessage , estes passos podem ser vistos no post anterior . Agora vamos montar um...