Ich habe ein Problem mit der Übergabe von Map Parametern oder Objekt an Retrofit POST-Anfrage.Wie übergeben Sie Map <String, String> -Parameter oder -Objekt an eine POST-Anfrage über Retrofit?
Ich folge square, kdubb labs Tutorials und this thread und ich konnte es nicht herausfinden.
Mein aktueller Code, der funktioniert:
public interface FacebookUser {
@FormUrlEncoded
@POST("/user/login-facebook")
void login(
@Field("fb_access_token") String fbAccessToken,
@Field("os") String os,
@Field("device") String device,
@Field("os_version") String osVersion,
@Field("app_version") String appVersion,
@Field("online") String online,
Callback<FacebookLoginUserResponse> callback
);
}
und Code:
RestAdapter restAdapter = new RestAdapter.Builder()
.setServer(requestMaker.getUrl())
.build();
FacebookUser facebookUser = restAdapter.create(FacebookUser.class);
facebookUser.login(getFbAccessToken(),
getString(R.string.config_os),
Info.getAndroidId(getBaseContext()),
Build.VERSION.RELEASE,
Info.getAppVersionName(getBaseContext()),
"" + 1,
new Callback<FacebookLoginUserResponse>() {
@Override
public void success(FacebookLoginUserResponse facebookLoginUserResponse, Response response) {
}
@Override
public void failure(RetrofitError retrofitError) {
}
});
Wenn ich versuche, diese Schnittstelle ich vom Server empfangen zu verwenden, die Parameter fehlen:
public interface FacebookUser {
@POST("/user/login-facebook")
void login(
@Body Map<String, String> map,
Callback<FacebookLoginUserResponse> callback
);
}
und Karte:
HashMap<String, String> map = new HashMap<String, String>();
map.put("fb_access_token", getFbAccessToken());
map.put("os", "android");
map.put("device", Info.getAndroidId(getBaseContext()));
map.put("os_version", Build.VERSION.RELEASE);
map.put("app_version", Info.getAppVersionName(getBaseContext()));
map.put("online", "" + 1);
Fragen: Was ist falsch? Wie kann ich Objekt an Anfrage übergeben?
** RestAdapter restAdapter = new RestAdapter.Builder() setEndpoint ("http://192.168.101.55/test"). build(); ** sollte funktionieren? es ist für (Version 1.5.0) richtig? –
@LOG_TAG sicher. Es sollte funktionieren. –
Warum ist das nicht in der Nachrüstdokumentation? – jvrodrigues