我在获取经过身份验证的用户时遇到问题。在它之前我得到了令牌和用户ID。现在我需要使用访问令牌和id从服务器获取用户。 I have header format
现在我尝试使用拦截器添加带有用户令牌和id的标头。
我的代码:
Interceptor interceptor = new Interceptor() {
@Override
public okhttp3.Response intercept(Chain chain) throws IOException {
Request newRequest = chain.request().newBuilder()
.addHeader("Accept", "application/json")
.addHeader("authorization", token) <-??
.addHeader("driver_id", id) <-??
.build();
return chain.proceed(newRequest);
}
};
OkHttpClient.Builder okHttpBuilder = new OkHttpClient.Builder();
okHttpBuilder.addInterceptor(interceptor);
OkHttpClient okHttpClient = okHttpBuilder.build();
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(BASE_URL)
.addConverterFactory(GsonConverterFactory.create())
.client(okHttpClient)
.build();
接口:
@GET("driver/v1/driver")
Call<Driver> getAuthorizedDriver();
不同的变种抛出401错误,不知道该怎么做 经度:
I/Response code: 401
I/Response message: Unauthorized`
答案 0 :(得分:7)
我明白了。 它必须看起来像:
@GET("driver/v1/driver")
Call<Driver> getAuthorizedDriver(@Header("authorization") String auth);
并且认证:
Call<Driver> call = apiInterface.getAuthorizedDriver("Token token=" + token + ", driver_id=" + id);
答案 1 :(得分:4)
尝试通过方法调用传递标头值:
@GET("driver/v1/driver")
Call<Driver> getAuthorizedDriver(@Header("authorization") String token,
@Header("driver_id") Integer id);
你也不必处理这一大块拦截器代码