บางทีคำตอบของฉันอาจจะค่อนข้างช้า แต่ครอบคลุม API ที่ต่ำกว่าและสูงกว่า 21 ระดับ
ในการเพิ่มส่วนหัวเราควรสกัดกั้นทุกคำขอและสร้างใหม่โดยมีส่วนหัวที่จำเป็น
ดังนั้นเราจำเป็นต้องแทนที่เมธอดshouldInterceptRequest ที่เรียกว่าในทั้งสองกรณี: 1. สำหรับ API จนถึงระดับ 21; 2. สำหรับ API ระดับ 21+
webView.setWebViewClient(new WebViewClient() {
@SuppressWarnings("deprecation")
@Override
public WebResourceResponse shouldInterceptRequest(WebView view, String url) {
return getNewResponse(url);
}
@TargetApi(Build.VERSION_CODES.LOLLIPOP)
@Override
public WebResourceResponse shouldInterceptRequest(WebView view, WebResourceRequest request) {
String url = request.getUrl().toString();
return getNewResponse(url);
}
private WebResourceResponse getNewResponse(String url) {
try {
OkHttpClient httpClient = new OkHttpClient();
Request request = new Request.Builder()
.url(url.trim())
.addHeader("Authorization", "YOU_AUTH_KEY")
.addHeader("api-key", "YOUR_API_KEY")
.build();
Response response = httpClient.newCall(request).execute();
return new WebResourceResponse(
null,
response.header("content-encoding", "utf-8"),
response.body().byteStream()
);
} catch (Exception e) {
return null;
}
}
});
หากควรประมวลผลประเภทการตอบกลับคุณสามารถเปลี่ยนแปลงได้
return new WebResourceResponse(
null,
response.header("content-encoding", "utf-8"),
response.body().byteStream()
);
ถึง
return new WebResourceResponse(
getMimeType(url),
response.header("content-encoding", "utf-8"),
response.body().byteStream()
);
และเพิ่มวิธีการ
private String getMimeType(String url) {
String type = null;
String extension = MimeTypeMap.getFileExtensionFromUrl(url);
if (extension != null) {
switch (extension) {
case "js":
return "text/javascript";
case "woff":
return "application/font-woff";
case "woff2":
return "application/font-woff2";
case "ttf":
return "application/x-font-ttf";
case "eot":
return "application/vnd.ms-fontobject";
case "svg":
return "image/svg+xml";
}
type = MimeTypeMap.getSingleton().getMimeTypeFromExtension(extension);
}
return type;
}