tutorial studio implementar example ejemplo consumir android get retrofit

android - studio - retrofit post example



Retrofit y GET usando parĂ¡metros (3)

Estoy tratando de enviar una solicitud a Google GeoCode API usando Retrofit. La interfaz de servicio se ve así:

public interface FooService { @GET("/maps/api/geocode/json?address={zipcode}&sensor=false") void getPositionByZip(@Path("zipcode") int zipcode, Callback<String> cb); }

Cuando llamo al servicio:

OkHttpClient okHttpClient = new OkHttpClient(); RestAdapter restAdapter = new RestAdapter.Builder().setEndpoint(Constants.GOOGLE_GEOCODE_URL).setClient(new OkClient(okHttpClient)).build(); FooService service = restAdapter.create(FooService.class); service.getPositionByZip(zipCode, new Callback<String>() { @Override public void success(String jsonResponse, Response response) { ... } @Override public void failure(RetrofitError retrofitError) { } });

Recibo el siguiente stacktrace:

06-07 13:18:55.337: E/AndroidRuntime(3756): FATAL EXCEPTION: Retrofit-Idle 06-07 13:18:55.337: E/AndroidRuntime(3756): Process: com.marketplacehomes, PID: 3756 06-07 13:18:55.337: E/AndroidRuntime(3756): java.lang.IllegalArgumentException: FooService.getPositionByZip: URL query string "address={zipcode}&sensor=false" must not have replace block. 06-07 13:18:55.337: E/AndroidRuntime(3756): at retrofit.RestMethodInfo.methodError(RestMethodInfo.java:120) 06-07 13:18:55.337: E/AndroidRuntime(3756): at retrofit.RestMethodInfo.parsePath(RestMethodInfo.java:216) 06-07 13:18:55.337: E/AndroidRuntime(3756): at retrofit.RestMethodInfo.parseMethodAnnotations(RestMethodInfo.java:162) 06-07 13:18:55.337: E/AndroidRuntime(3756): at

Eché un vistazo a la pregunta de StackOverflow: ¿ Retrofit: múltiples parámetros de consulta en el comando @GET? pero no parecía aplicable.

Tomé el código más o menos literal desde aquí: http://square.github.io/retrofit/ así que estoy un poco perdido para entender el problema.

¿Pensamientos?


AFAIK, {...} solo se puede usar como una ruta, no dentro de un parámetro de consulta. Pruebe esto en su lugar:

public interface FooService { @GET("/maps/api/geocode/json?sensor=false") void getPositionByZip(@Query("address") String address, Callback<String> cb); }

Si tiene una cantidad desconocida de parámetros que aprobar, puede usar algo como esto:

public interface FooService { @GET("/maps/api/geocode/json") @FormUrlEncoded void getPositionByZip(@FieldMap Map<String, String> params, Callback<String> cb); }


También quería aclarar que si tiene parámetros de URL complejos para compilar, deberá compilarlos manualmente. es decir, si su consulta es example.com/?latlng=-37,147 , en lugar de proporcionar los valores lat y lng individualmente, deberá compilar la cadena latlng externamente, luego proporcionarla como un parámetro, es decir:

public interface LocationService { @GET("/example/") void getLocation(@Query(value="latlng", encoded=true) String latlng); }

Tenga en cuenta que encoded=true es necesario, de lo contrario, la modificación codificará la coma en el parámetro de cadena. Uso:

String latlng = location.getLatitude() + "," + location.getLongitude(); service.getLocation(latlng);


@QueryMap funcionó para mí en lugar de FieldMap

Si tiene un grupo de parámetros GET, otra forma de pasarlos a su url es un HashMap .

class YourActivity extends Activity { private static final String BASEPATH = "http://www.example.com"; private interface API { @GET("/thing") void getMyThing(@QueryMap Map<String, String> params, new Callback<String> callback); } public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.your_layout); RestAdapter rest = new RestAdapter.Builder().setEndpoint(BASEPATH).build(); API service = rest.create(API.class); Map<String, String> params = new HashMap<String, String>(); params.put("key1", "val1"); params.put("key2", "val2"); // ... as much as you need. service.getMyThing(params, new Callback<String>() { // ... do some stuff here. }); } }

La URL llamada será http://www.example.com/thing/?key1=val1&key2=val2