2016-06-02 32 views
5

Nel mio caso, quando ho messo oggetto classe sub a richiesta retrofit va vuoto nel corpo della richiestaImpossibile convertire oggetto sottoclasse di richiesta JSON corpo in retrofit 2.0 con 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); 

ora sto passando FbUserObject

networkAPI.createUserNew(fbUserObject).subscribe(); 

quindi l'oggetto diventa vuoto nel corpo. vedere il mio registro

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) 

Ho anche passare attraverso questo collegamento stackover flusso Polymorphism with gson

avrei dovuto scrivere il mio GSON Converter?

risposta

3

Gson tenta di serializzare la classe User che non ha campi.

Quello che dovete fare è quello di registrare la scheda di tipo a 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

Sembra una soluzione. Ora sono un panda triste :(Sto cercando un modo per automatizzare il processo, probabilmente la riflessione è la mia scelta –

0

Grazie a @pixel per la sua risposta - ha contribuito a scavare nella giusta direzione in modo che ho si avvicinò con la soluzione più generica e ora sono di nuovo felice:

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(); 

credo che si può anche usare Object invece di User o qualunque sia l'/ interfaccia di classe radice è così gestisce tutte le possibili sottoclassi automaticamente come gerarchie più complesse vengono aggiunti al progetto - non sono sicuro di tutti gli inconvenienti di un approccio così generico al momento però.