Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/jquery/76.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 改装2.0多拦截器_Java_Request_Retrofit_Okhttp3 - Fatal编程技术网

Java 改装2.0多拦截器

Java 改装2.0多拦截器,java,request,retrofit,okhttp3,Java,Request,Retrofit,Okhttp3,我正在进行改装,需要能够使用多个拦截器。目前,我正在使用一个自动附加身份验证令牌,但我需要能够在没有身份验证令牌的情况下进行调用。如果我添加了另一个头中没有auth令牌的拦截器,我如何使用该拦截器而不是auth令牌拦截器 val interceptor: Interceptor = Interceptor { chain -> val newRequest = chain.request().newBuilder(). addHeader("Auth

我正在进行改装,需要能够使用多个拦截器。目前,我正在使用一个自动附加身份验证令牌,但我需要能够在没有身份验证令牌的情况下进行调用。如果我添加了另一个头中没有auth令牌的拦截器,我如何使用该拦截器而不是auth令牌拦截器

    val interceptor: Interceptor = Interceptor { chain ->
    val newRequest = chain.request().newBuilder().
            addHeader("Auth_Token", pref.getString(PSPreferences.prefAuthKey, "")).
            cacheControl(CacheControl.FORCE_NETWORK).
            build()
    chain.proceed(newRequest)
}

okHttpClient = OkHttpClient.Builder().
        readTimeout(1, TimeUnit.MINUTES).
        connectTimeout(1, TimeUnit.MINUTES).
        addInterceptor(interceptor).build()

val retrofitInstance = Retrofit.Builder()
        .baseUrl(APIEndpointInterface.BASE_URL)
        .client(okHttpClient)
        .addConverterFactory(GsonConverterFactory.create())
        .build()
apiInterface = retrofitInstance.create<APIEndpointInterface>(APIEndpointInterface::class.java)
val拦截器:拦截器=拦截器{chain->
val newRequest=chain.request().newBuilder()。
addHeader(“Auth_标记”,pref.getString(PSPreferences.prefAuthKey,”)。
cacheControl(cacheControl.FORCE_网络)。
构建()
链。继续(新请求)
}
okHttpClient=okHttpClient.Builder()。
readTimeout(1,时间单位为分钟)。
连接超时(1,时间单位为分钟)。
addInterceptor(拦截器).build()
val reformationInstance=reformation.Builder()
.baseUrl(APINDPOInterface.BASE_URL)
.客户(okHttpClient)
.addConverterFactory(GsonConverterFactory.create())
.build()
apiInterface=instance.create(APIEndpointInterface::class.java)

OkHttpClient
维护一个您可以访问的拦截器列表,但它是一个不可修改的集合

我认为这给我们留下了三个选择:

  • 创建两个OkHttpClient实例,并通过两个改进 实例,一个用于未经验证的请求,另一个用于 已验证的请求

  • 检查您是否应该使用拦截器,例如,在您的身份验证拦截器中,您可以首先检查您的令牌首选项中是否存在密钥,如果存在,请使用该密钥;如果没有,您只需继续而不修改任何内容。您也可以为未经验证的拦截器执行此操作。我认为这是最简单的解决方案

  • 创建一个拦截器,它将维护一个可修改的列表 你可以随意添加和删除的拦截器。你需要 要保留对该拦截器的引用,可以将其设置为Singleton

  • 对于第三个选项,我提供了一个非常简单的示例:

    public class HttpRequestResponseInterceptor implements Interceptor {
    
        public final List<RequestInterceptor> requestInterceptors = new ArrayList<>();
        public final List<ResponseInterceptor> responseInterceptors = new ArrayList<>();
    
        @Override
        public Response intercept(Chain chain) throws IOException {
    
            Request request = chain.request();
    
            for (RequestInterceptor interceptor : requestInterceptors) {
                request = interceptor.intercept(request);
            }
    
            Response response = chain.proceed(request);
    
            for (ResponseInterceptor interceptor : responseInterceptors) {
                response = interceptor.intercept(response);
            }
    
            return response;
        }
    
        public interface RequestInterceptor {
            Request intercept(Request request) throws IOException;
        }
    
        public interface ResponseInterceptor {
            Response intercept(Response response) throws IOException;
        }
    }
    
    然后,您需要将此拦截器添加到主拦截器两次,一次添加到
    请求拦截器
    ,一次添加到
    响应拦截器
    (或者仅添加到其中一个,如果它只截获请求或响应)


    这个例子还远远不够完整。此解决方案的好处是,它增加了添加和删除拦截器的能力,而无需重新创建
    OkHttpClient
    实例。例如,如果您想支持重试请求,则需要额外的工作。

    嘿,您最终是否解决了这个问题?我在找完全一样的东西。
    public class ExampleInterceptor implements HttpRequestResponseInterceptor.RequestInterceptor,
     HttpRequestResponseInterceptor.ResponseInterceptor {
    
        @Override
        public Request intercept(Request request) throws IOException {
            return request.newBuilder().addHeader("REQUEST_HEADER", "EXAMPLE").build();
        }
    
        @Override
        public Response intercept(Response response) throws IOException {
            return response.newBuilder().addHeader("RESPONSE_HEADER", "EXAMPLE").build();
        }
    }