Okhttp攔截器分為兩大類惠爽,一類是應(yīng)用攔截器癌蓖,另一類是網(wǎng)絡(luò)攔截器。
Application Interceptor
適用于在請求前統(tǒng)一加一些公共參數(shù)婚肆,例如在添加App的版本號租副,用戶ID,手機版本號,運營商類型等參數(shù)较性∮蒙或者對響應(yīng)體的數(shù)據(jù)進行json轉(zhuǎn)化结胀。
NetworkInterceptor
在這一層攔截器中可以獲取到最終發(fā)送請求的request,也可以獲取到真正發(fā)生網(wǎng)絡(luò)請求后回來的response響應(yīng)责循,從而修改對應(yīng)的請求或者響應(yīng)的數(shù)據(jù)糟港。
兩種攔截器的區(qū)別
Application Interceptor
- 不需要去關(guān)心發(fā)生的重定向和重試操作。因為它處于第一個攔截器院仿,會獲取到最終響應(yīng)的response秸抚。
- 只會被調(diào)用一次,即使這個響應(yīng)是從緩存中獲取的歹垫。
- 只關(guān)注原始的請求剥汤,不去關(guān)心請求的資源是否發(fā)生了變化,我只關(guān)注最后的response結(jié)果而已排惨。
- 因為是第一個被執(zhí)行的攔截器吭敢,因此呢它有權(quán)決定是否要調(diào)用其他攔截,也就是Chain.proceed()方法是否要執(zhí)行暮芭。
- 因為是第一個被執(zhí)行的攔截器省有,因此它可以有多次調(diào)用Chain.proceed()方法,其實也就是相當(dāng)于與重新請求的作用谴麦。
Network Interceptor
- 因為NetWorkInterceptor是排在第6個攔截器中蠢沿,因此可以操作經(jīng)過RetryAndFollowup進行失敗重試或者重定向之后得到response。
- 對于從緩存獲取的response則不會去觸發(fā)NetworkInterceptor匾效。因為響應(yīng)會從CacheInterceptor返回舷蟀。
- 觀察數(shù)據(jù)在網(wǎng)絡(luò)中的傳輸。
- 可以獲得裝在請求的連接面哼。
例如自定義token攔截器(示例):
public class TokenInterceptor implements Interceptor {
public static int NEED_AUTH=401;
@Override
public Response intercept(Chain chain) throws IOException {
Request request=chain.request();
Response originalResponse=chain.proceed(request);
//401表示需要重新登陸或者token失效,大致的意思是
//當(dāng)發(fā)起請求發(fā)現(xiàn)服務(wù)器返回token值過期的信息野宜,這個時候就重新獲取最新的Token值然后重新發(fā)起請求
if(originalResponse.code()==NEED_AUTH){
//TODO 獲取新token,這里只給出思路
String newToken="newToken";
//然后保存token值
Request newRequest=request.newBuilder()
.header("token",newToken)//為請求重新添加Token值
.build();
originalResponse.body().close();
// RequestBody requestBody= new FormBody.Builder().build();
return chain.proceed(newRequest);
}
return originalResponse;
}
}
總結(jié)
不管是Application Interceptor還是NetWork Interceptor這兩種攔截器都有一個共同的功能,那就是可以修改對應(yīng)的請求或者是響應(yīng)的數(shù)據(jù)魔策。