Consignation des demandes et des réponses dans Retrofit 2
Dans Retrofit 1, la journalisation du JSON exact envoyé dans une requête était simple à l'aide de setLog() et setLogLevel(). Cependant, Retrofit 2 a depuis rendu ces méthodes obsolètes, laissant les développeurs se demander comment enregistrer correctement le trafic réseau.
Utilisation de HttpLoggingInterceptor
La solution réside dans HttpLoggingInterceptor, qui peut être ajouté au OkHttpClient pour enregistrer la demande et la réponse bodys :
HttpLoggingInterceptor interceptor = new HttpLoggingInterceptor(); interceptor.setLevel(HttpLoggingInterceptor.Level.BODY);
Ensuite, créez un objet Retrofit à l'aide de OkHttpClient avec l'intercepteur ajouté :
OkHttpClient client = new OkHttpClient.Builder().addInterceptor(interceptor).build(); Retrofit retrofit = new Retrofit.Builder() .baseUrl(...) .client(client) .addConverterFactory(GsonConverterFactory.create()) .build();
La définition du niveau de journalisation sur BODY fournira des journaux détaillés similaires à ceux générés par setLogLevel (RestAdapter.LogLevel.FULL) dans Retrofit 1.
Résolution ClassNotFoundException
Si vous rencontrez une java.lang.ClassNotFoundException, assurez-vous que la version de logging-interceptor correspond à votre version Retrofit. Dans certains cas, les anciennes versions de Retrofit peuvent nécessiter une version antérieure de l'intercepteur de journalisation.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!