2016-06-02 6 views
5

in meinem Fall zu beantragen, wenn ich Unterklassenobjekt in Retrofit-Anfrage stellen geht es leer in Anfrage KörperKann nicht konvertieren Subklassen-Objektkörper json in Retrofit 2.0 mit GsonConverterFactory

interface User{ // my super interface 
} 

class FbUser implements User{ // my sub class 
    public String name; 
    public String email; 
} 

interface APIInterface{ 
    @POST(APIConstants.LOGIN_URL) 
    Observable<LoginAPIResponse> createUserNew(@Body User user); 
} 



Retrofit retrofit = new Retrofit.Builder() 
       .baseUrl(baseUrl) 
       .addConverterFactory(GsonConverterFactory.create(new Gson())) 
       .addCallAdapterFactory(RxErrorHandlingCallAdapterFactory.create()) 
       .client(okHttpClient) 
       .build(); 

    APIInterface networkAPI = retrofit.create(APIInterface.class); 

jetzt i FbUserObject

bin vorbei
networkAPI.createUserNew(fbUserObject).subscribe(); 

dann Objekt wird leer im Körper. mein log

D/OkHttp: Content-Type: application/json; charset=UTF-8 
D/OkHttp: Content-Length: 2 
D/OkHttp: Accept: application/json 
D/OkHttp: TT-Mobile-Post: post 
D/OkHttp: {} 
D/OkHttp: --> END POST (2-byte body) 

sehe ich gehen auch durch diese stackover Flow Link Polymorphism with gson

Sollte ich habe meine eigene Gson Converter schreiben?

Antwort

3

Gson versucht die Klasse User zu serialisieren, die keine Felder enthält.

Was Sie tun müssen, ist der Typ Adapter registrieren Gson:

retrofitBuilder.addConverterFactory(GsonConverterFactory.create(new GsonBuilder() 
      .registerTypeAdapter(User.class, new JsonSerializer<User>() { 
       @Override 
       public JsonElement serialize(User src, Type typeOfSrc, JsonSerializationContext context) { 
        if (src instanceof FbUser) { 
         return context.serialize(src, FbUser.class); 
        } 
        return context.serialize(src); 
       } 
      }).create())); 
+1

Sieht wie eine Lösung aus. Ich bin jetzt ein trauriger Panda :(Ich suche nach einer Möglichkeit, den Prozess zu automatisieren. Wahrscheinlich ist Reflexion meine Wahl –

0

Dank für seine Antwort auf @pixel - es in die richtige Richtung zu graben half so habe ich kam mit mehr generischen Lösung auf und jetzt bin ich wieder glücklich:

Gson gson = new GsonBuilder() 
      .registerTypeAdapter(User.class, new JsonSerializer<User>() { 

       @Override 
       public JsonElement serialize(User src, Type typeOfSrc, JsonSerializationContext context) { 
        return context.serialize(src, src.getClass()); 
       } 
      }) 
      .create(); 

ich denke, man selbst Object verwenden kann statt User oder was auch immer die Wurzelklasse/Schnittstelle ist so behandeln sie alle möglichen Unterklassen automatisch als komplexe Hierarchien zu dem Projekt hinzugefügt werden - bin mir nicht sicher irgendwelche Nachteile eines solchen generischen Ansatzes im Moment.