記錄下開發遇到的小狀況。
後臺要求將userID放到請求url中,即:http://domin.com/用戶ID。
參考了這位作者的處理方式,感謝他
直接貼代碼:
import java.io.IOException;
import kotlin.Pair;
import okhttp3.HttpUrl;
import okhttp3.Interceptor;
import okhttp3.Request;
public class ChangeUrlIntercept implements Interceptor {
private Context context;
public ChangeUrlIntercept(Context context) {
this.context = context;
}
@Override
public okhttp3.Response intercept(Chain chain) throws IOException {
//獲取request
Request request = chain.request();
//獲取request的創建者builder
Request.Builder builder = request.newBuilder();
//ALog.e( request.method());
HttpUrl oldHttpUrl = request.url();
//不能在登錄接口裏做此驗證
if (!request.method().equalsIgnoreCase("POST")
|| !oldHttpUrl.toString().contains("Api/UserLogOn")) {
Pair<Boolean, User> result = CommonUtils.getUser(context);
if (result.component1()) {
//重建新的HttpUrl,修改需要修改的url部分
HttpUrl newFullUrl = oldHttpUrl
.newBuilder()
.scheme(oldHttpUrl.scheme())
.host(oldHttpUrl.host())
.port(oldHttpUrl.port())
.addEncodedPathSegment(result.component2().tskey)
.build();
// ALog.e(newFullUrl.toString() + " 新的請求接口");
return chain.proceed(builder.url(newFullUrl).build());
} else {
return chain.proceed(request);
}
}
return chain.proceed(request);
}
}