Könntest du mir bitte meinen Code falsch nennen, ich könnte dem Interzeptor keinen Header "Authorization" hinzufügen. Wenn ich eine Anfrage mache, löst es einen Fehler aus retrofit2.adapter.rxjava.HttpException: HTTP 401 Unauthorized. Aber wenn ich Header-Token für jede AnfrageWarum kann ich Header hinzufügen, Interceptor requeset OkHttp auf Retrofit?
hinzufügenDann funktioniert es.
Hier ist mein Code:
protected Retrofit retrofit;
protected OkHttpClient client;
protected T api;
protected UserCredential userCredential;
public RestClient(Class<T> type) {
if (client == null) {
synchronized (OkHttpClient.class) {
client = new OkHttpClient();
client.newBuilder().addInterceptor(chain -> {
Request original = chain.request();
Request.Builder builder = original.newBuilder();
if (GrabDoiApplication.getInstance().getCurrentCredentials() != null) {
String token = GrabDoiApplication.getInstance().getCurrentCredentials().getToken();
if (token != null) {
builder.addHeader("Authorization", token);
}
}
builder.method(original.method(), original.body());
return chain.proceed(builder.build());
}).build();
if (retrofit == null) {
synchronized (Retrofit.class) {
Retrofit.Builder retrofitBuilder = new Retrofit.Builder()
.baseUrl(Constants.GRABDOI_SERVER_URL)
.client(client)
.addConverterFactory(GsonConverterFactory.create())
.addCallAdapterFactory(RxJavaCallAdapterFactory.create());
retrofit = retrofitBuilder.build();
}
}
}
}
api = retrofit.create(type);
}
Sie haben Recht. Vielen Dank. –