API de OAuth para Four Square
-
23-09-2019 - |
Pregunta
tiene un uso bien a nadie API de Java para cuatro oauth cuadrado? Busco algo que es seguro para hilos?
Saludos,
Solución
foursquare4j , pero no pudo conseguir que se recupere con éxito un acceso token, que es el último paso necesario antes de llamar a la firma de llamadas a la API de Foursquare. Por lo que me pasa a usar señal a conseguir a través de la broca de autenticación y obtener un token de acceso y secreto, y luego se usa foursquare4j ya que encapsula la API como un modelo de objetos muy agradable. No sé si poste indicador o foursquare4j son inherentemente seguro para subprocesos - se podía hacer esa pregunta en sus foros. A continuación se muestra una versión aplanada del código que estoy utilizando para mi aplicación de autenticación. Estoy usando el framework Play - Autorizar () recibe la solicitud inicial de autenticación y oauth () es donde foursquare redirecciones para el acceso una vez que el usuario ha permitido
.public class Foursquare extends Controller {
static final String FOURSQUARE_OAUTH_REQUEST_TOKEN = "http://foursquare.com/oauth/request_token";
static final String FOURSQUARE_OAUTH_ACCESS_TOKEN = "http://foursquare.com/oauth/access_token";
static final String FOURSQUARE_OAUTH_AUTHORIZE = "http://foursquare.com/oauth/authorize";
static final String CONSUMER_KEY = "N4FKW2GFLMU1UGR3DDQYE4IGJQRGID1JFXYPJS3XFLZN3EU6";
static final String CONSUMER_SECRET = "DDGHBF25J3RJDD4N4QC2CMRF8YMA1CG94OGFRPTY4RQNLMVH";
// Handle Request for foursquare Authorization
public static void authorize() throws OAuthMessageSignerException, OAuthNotAuthorizedException, OAuthExpectationFailedException, OAuthCommunicationException {
oauth.signpost.OAuthProvider provider = new DefaultOAuthProvider(FOURSQUARE_OAUTH_REQUEST_TOKEN, FOURSQUARE_OAUTH_ACCESS_TOKEN,FOURSQUARE_OAUTH_AUTHORIZE);
oauth.signpost.OAuthConsumer consumer = new DefaultOAuthConsumer(CONSUMER_KEY,CONSUMER_SECRET);
String authURL;
authURL = provider.retrieveRequestToken(consumer,"");
String tokenSecret = consumer.getTokenSecret();
session.put("secret", tokenSecret);
redirect(authURL);
}
// Handle call back from foursquare after user Accepts
public static void oauth() throws IOException, OAuthMessageSignerException, OAuthNotAuthorizedException, OAuthExpectationFailedException, OAuthCommunicationException {
oauth.signpost.OAuthProvider provider = new DefaultOAuthProvider(FOURSQUARE_OAUTH_REQUEST_TOKEN, FOURSQUARE_OAUTH_ACCESS_TOKEN,FOURSQUARE_OAUTH_AUTHORIZE);
oauth.signpost.OAuthConsumer consumer = new DefaultOAuthConsumer(CONSUMER_KEY,CONSUMER_SECRET);
String secret = session.get("secret");
String pinCode = params.get("oauth_token");
consumer.setTokenWithSecret(pinCode, secret);
provider.retrieveAccessToken(consumer, pinCode);
// Get the access token and secret
String token = consumer.getToken();
String tokenSecret = consumer.getTokenSecret();
// Set foursquare4j Credentials
foursquare4j.type.Credentials credentials = new Credentials();
credentials.setTokenSecret(tokenSecret);
credentials.setAccessToken(token);
foursquare4j.oauth.OAuthConsumer newConsumer = new OAuthConsumer(CONSUMER_KEY, CONSUMER_SECRET);
foursquare4j.oauth.FoursquareOAuthImpl fs = new FoursquareOAuthImpl(newConsumer, credentials);
try {
// Get last 50 checkins
Checkins checkins = fs.history("50", "");
render(checkins);
} catch (FoursquareException e) {
e.printStackTrace();
}
}
}
Otros consejos
Hola Andrew Casi estoy terminado de definir un módulo para la super cool Juego Marco para hablar a través de Foursquare OAuth.
Se puede seguir el progreso en mi blog http://geeks.aretotally.in o Github https://github.com/feliperazeek/playframework-foursquare .
Tenga cuidado porque Foursquare está apagando OAuth 1 a favor de OAuth 2 muy pronto.