studio - No se puede crear el convertidor para mi clase en la biblioteca de Android Retrofit
manual de programacion android pdf (9)
Antes de
2.0.0
, el convertidor predeterminado era un convertidor gson, pero en
2.0.0
y posteriores el convertidor predeterminado es
ResponseBody
.
De los documentos:
Por defecto, Retrofit solo puede deserializar cuerpos HTTP en el tipo
ResponseBody
de OkHttp y solo puede aceptar su tipo@Body
para@Body
.
En
2.0.0+
, debe especificar explícitamente que desea un convertidor Gson:
Retrofit retrofit = new Retrofit.Builder()
.baseUrl("**sample base url here**")
.addConverterFactory(GsonConverterFactory.create())
.build();
También deberá agregar la siguiente dependencia a su archivo gradle:
compile ''com.squareup.retrofit2:converter-gson:2.1.0''
Use la misma versión para el convertidor que para su modificación. Lo anterior coincide con esta dependencia de actualización:
compile (''com.squareup.retrofit2:retrofit:2.1.0'')
Además, tenga en cuenta que al escribir esto, los documentos de actualización no están completamente actualizados, por lo que ese ejemplo lo metió en problemas. De los documentos:
Nota: Este sitio todavía está en proceso de expansión para las nuevas API 2.0.
Estoy migrando de usar Volley a Retrofit, ya tengo la clase gson que usé antes para convertir la respuesta JSONObject en un objeto que implementa anotaciones gson. Cuando estoy tratando de hacer una solicitud de obtención de http usando la actualización, pero mi aplicación se bloquea con este error:
Unable to start activity ComponentInfo{com.lightbulb.pawesome/com.example.sample.retrofit.SampleActivity}: java.lang.IllegalArgumentException: Unable to create converter for class com.lightbulb.pawesome.model.Pet
for method GitHubService.getResponse
Estoy siguiendo la guía en el sitio de actualización y se me ocurren estas implementaciones:
Esta es mi actividad en la que intento ejecutar la solicitud http retro:
public class SampleActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sample);
Retrofit retrofit = new Retrofit.Builder()
.baseUrl("**sample base url here**")
.build();
GitHubService service = retrofit.create(GitHubService.class);
Call<Pet> callPet = service.getResponse("41", "40");
callPet.enqueue(new Callback<Pet>() {
@Override
public void onResponse(Response<Pet> response) {
Log.i("Response", response.toString());
}
@Override
public void onFailure(Throwable t) {
Log.i("Failure", t.toString());
}
});
try{
callPet.execute();
} catch (IOException e){
e.printStackTrace();
}
}
}
Mi interfaz que resultó ser mi API
public interface GitHubService {
@GET("/ **sample here** /{petId}/{otherPet}")
Call<Pet> getResponse(@Path("petId") String userId, @Path("otherPet") String otherPet);
}
Y finalmente la clase Pet, que debería ser la respuesta:
public class Pet implements Parcelable {
public static final String ACTIVE = "1";
public static final String NOT_ACTIVE = "0";
@SerializedName("is_active")
@Expose
private String isActive;
@SerializedName("pet_id")
@Expose
private String petId;
@Expose
private String name;
@Expose
private String gender;
@Expose
private String age;
@Expose
private String breed;
@SerializedName("profile_picture")
@Expose
private String profilePicture;
@SerializedName("confirmation_status")
@Expose
private String confirmationStatus;
/**
*
* @return
* The confirmationStatus
*/
public String getConfirmationStatus() {
return confirmationStatus;
}
/**
*
* @param confirmationStatus
* The confirmation_status
*/
public void setConfirmationStatus(String confirmationStatus) {
this.confirmationStatus = confirmationStatus;
}
/**
*
* @return
* The isActive
*/
public String getIsActive() {
return isActive;
}
/**
*
* @param isActive
* The is_active
*/
public void setIsActive(String isActive) {
this.isActive = isActive;
}
/**
*
* @return
* The petId
*/
public String getPetId() {
return petId;
}
/**
*
* @param petId
* The pet_id
*/
public void setPetId(String petId) {
this.petId = petId;
}
/**
*
* @return
* The name
*/
public String getName() {
return name;
}
/**
*
* @param name
* The name
*/
public void setName(String name) {
this.name = name;
}
/**
*
* @return
* The gender
*/
public String getGender() {
return gender;
}
/**
*
* @param gender
* The gender
*/
public void setGender(String gender) {
this.gender = gender;
}
/**
*
* @return
* The age
*/
public String getAge() {
return age;
}
/**
*
* @param age
* The age
*/
public void setAge(String age) {
this.age = age;
}
/**
*
* @return
* The breed
*/
public String getBreed() {
return breed;
}
/**
*
* @param breed
* The breed
*/
public void setBreed(String breed) {
this.breed = breed;
}
/**
*
* @return
* The profilePicture
*/
public String getProfilePicture() {
return profilePicture;
}
/**
*
* @param profilePicture
* The profile_picture
*/
public void setProfilePicture(String profilePicture) {
this.profilePicture = profilePicture;
}
protected Pet(Parcel in) {
isActive = in.readString();
petId = in.readString();
name = in.readString();
gender = in.readString();
age = in.readString();
breed = in.readString();
profilePicture = in.readString();
}
@Override
public int describeContents() {
return 0;
}
@Override
public void writeToParcel(Parcel dest, int flags) {
dest.writeString(isActive);
dest.writeString(petId);
dest.writeString(name);
dest.writeString(gender);
dest.writeString(age);
dest.writeString(breed);
dest.writeString(profilePicture);
}
@SuppressWarnings("unused")
public static final Parcelable.Creator<Pet> CREATOR = new Parcelable.Creator<Pet>() {
@Override
public Pet createFromParcel(Parcel in) {
return new Pet(in);
}
@Override
public Pet[] newArray(int size) {
return new Pet[size];
}
};
}
Basado en el comentario principal, actualicé mis importaciones
implementation ''com.squareup.retrofit2:retrofit:2.1.0''
implementation ''com.squareup.retrofit2:converter-gson:2.1.0''
He utilizado http://www.jsonschema2pojo.org/ para crear pojo a partir de los resultados de Spotify json y me he asegurado de especificar el formato Gson.
En estos días hay complementos de Android Studio que pueden crear los modelos de datos de Pojo o Kotlin por usted. Una gran opción para mac es Quicktype. https://itunes.apple.com/us/app/paste-json-as-code-quicktype/id1330801220
En mi caso, el problema era que mi modelo SUPERCLASS tenía este campo definido en él. Muy estúpido, lo sé ...
En mi caso, se debió a tratar de llevar una Lista devuelta por mi servicio a una ArrayList. Entonces lo que tuve fue:
@Json(name = "items")
private ArrayList<ItemModel> items;
cuando debería haber tenido
@Json(name = "items")
private List<ItemModel> items;
¡Espero que esto ayude a alguien!
En mi caso, tenía un objeto TextView dentro de mi clase modal y GSON no sabía cómo serializarlo. Marcarlo como ''transitorio'' resolvió el problema.
Esto puede ayudar a alguien
En mi caso, por error, escribí SerializedName como este
@SerializedName("name","time")
String name,time;
Debería ser
@SerializedName("name")
String name;
@SerializedName("time")
String time;
Hola, estaba pasando por el mismo problema hoy, me llevó todo un día encontrar una solución, pero esta es la solución que encontré finalmente. Estoy usando Dagger en mi código y necesitaba implementar el convertidor Gson en mi instancia de actualización.
entonces este era mi código antes
@Provides
@Singleton
Retrofit providesRetrofit(Application application,OkHttpClient client) {
String SERVER_URL=URL;
Retrofit.Builder builder = new Retrofit.Builder();
builder.baseUrl(SERVER_URL);
return builder
.client(client)
.build();
}
esto fue lo que terminé con
@Provides
@Singleton
Retrofit providesRetrofit(Application application,OkHttpClient client, Gson gson) {
String SERVER_URL=URL;
Retrofit.Builder builder = new Retrofit.Builder();
builder.baseUrl(SERVER_URL);
return builder
.client(client)
.addConverterFactory(GsonConverterFactory.create(gson))
.build();
}
observe cómo no hay convertidor en el primer ejemplo y la adición si no ha instanciado Gson lo agrega así
@Provides
@Singleton
Gson provideGson() {
GsonBuilder gsonBuilder = new GsonBuilder();
gsonBuilder.setFieldNamingPolicy(FieldNamingPolicy.LOWER_CASE_WITH_UNDERSCORES);
return gsonBuilder.create();
}
y asegúrese de haberlo incluido en la llamada al método de modificación.
Una vez más espero que esto ayude a alguien como yo.
La publicación de @ Silmarilos me ayudó a resolver esto. En mi caso, fue que usé "id" como un nombre serializado, como este:
@SerializedName("id")
var node_id: String? = null
y lo cambié a
@SerializedName("node_id")
var node_id: String? = null
Todos trabajando ahora. Olvidé que ''id'' es un atributo predeterminado.
Si alguien se encuentra con esto en el futuro porque está tratando de definir su propia fábrica de convertidores personalizados y está recibiendo este error, también puede ser causado por tener múltiples variables en una clase con un nombre mal escrito o el mismo nombre serializado. ES DECIR:
public class foo {
@SerializedName("name")
String firstName;
@SerializedName("name")
String lastName;
}
Tener nombres serializados definidos dos veces (probablemente por error) también arrojará exactamente el mismo error.
Actualización : tenga en cuenta que esta lógica también es válida a través de la herencia. Si se extiende a una clase principal con un objeto que tiene el mismo nombre serializado que en la subclase, causará este mismo problema.