我知道这就是拦截器的工作方式,来自应用程序的请求通过 OkHttp 核心,通过改造包装器和 OkHttpp 核心调用发出实际的网络请求,并通过改造包装器对应用程序拦截器响应的网络响应。
有没有办法避免从应用程序拦截器调用实际请求,例如,在某些情况下,应用程序拦截器检查请求 URL 是否是某个字符串,然后,在这种情况下,不要调用实际的网络请求并直接从应用程序拦截器返回硬编码的响应?
最佳答案
您可以返回一个新的响应而不是调用 chain.proceed()
它会阻止链条向前移动。你可以这样做。
if(something)
return Response.Builder()
.code(200) //Or whatever you might later check from
.protocol(Protocol.HTTP_2) //or 1
.message("SUCCESS")
.body(ResponseBody.create(MediaType.get("application/json"), "{\"x\": 1}")) // your response
.request(chain.request())
.build()
我还建议定义一个注释,并在你的拦截器中获取它,而不是检查 URL。 request.tag(Invocation::class.java)?.method()?.getAnnotation(YourAnnotation::class.java)
关于android - 改造 - 是否可以避免从应用程序拦截器调用实际 api 并返回硬编码响应?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67170280/