iOS11 WKWebView內(nèi)容過(guò)濾規(guī)則詳解
WKWebView中新增了一個(gè)功能,可以對(duì)WebView的內(nèi)容添加一些自定義的過(guò)濾規(guī)則。這個(gè)功能原來(lái)在 Safari Extension 中被引入,從 11 開(kāi)始同樣適用于WKWebView。
使用方法
原理上就是提供一個(gè) JSON 給 WebKit,這個(gè) JSON 包括內(nèi)容的觸發(fā)規(guī)則(trigger)和對(duì)應(yīng)的處理方式(action)。比如:
[{
"trigger": {
"url-filter": ".*" },
"action": {
"type": "make-https"}
}]
WebKit 會(huì)把攔截規(guī)則編譯成高效的二進(jìn)制碼。使用方法如下:
WKContentRuleListStore.default().compileContentRuleList(
forIdentifier: "ContentBlockingRules",
encodedContentRuleList: jsonString) { (contentRuleList, error) in
if let error = error {
return
}
let configuration = WKWebViewConfiguration()
configuration.userContentController.add(ruleList!)
}
可使用的處理方式:Action
對(duì)應(yīng)的 Action 有以下幾種:
- block:放棄加載資源,如果該資源已經(jīng)緩存也忽略緩存
- block-cookies:所有發(fā)送的請(qǐng)求的header中都會(huì)過(guò)濾掉cookie
- css-display-none:隱藏使用 CSS selector 的頁(yè)面元素,同時(shí)還有關(guān)聯(lián)的selector:
"action": { "type": "css-display-none", "selector": "#newsletter, :matches(.main-page, .article) .news-overlay" } - ignore-previous-rules:前面觸發(fā)的規(guī)則不執(zhí)行
- make-https:把網(wǎng)頁(yè)里的 http 請(qǐng)求改為 https 請(qǐng)求
規(guī)則觸發(fā)器:trigger
觸發(fā)器必須有url-filter,可選的鍵有:resource-type、if-domain、unless-domain
- url-filter 匹配 URL 的正則表達(dá)式
- if-domain 或者 unless-domain if-domain:規(guī)則只在這些域名下起作用。unless-domain:這些域名除外。
- resource-type 資源的類型,對(duì)應(yīng)的 value 有:
- document
- image
- style-sheet
- script
- font
- raw (Any untyped load, such as XMLHttpRequest)
- svg-document
- media
- popup
- load-type 資源的歸屬。默認(rèn)是全部的資源。如果收到填有兩種 value:
- first-party 只有當(dāng)資源和頁(yè)面的scheme、域名、端口一致時(shí)才觸發(fā)
- third-party 只有當(dāng)資源和頁(yè)面的域名不一致時(shí)才觸發(fā)
舉個(gè) trigger 的示例就是:
"trigger": {
"url-filter": ".*",
"resource-type": ["image", "style-sheet"],
"unless-domain": ["your-content-server.com", "trusted-content-server.com"]
}
總結(jié)
可以通過(guò)配置規(guī)則攔截頁(yè)面里的資源請(qǐng)求、隱藏頁(yè)面里的指定元素、將http請(qǐng)求轉(zhuǎn)換成https。
參考
WWDC 17:customized_loading_in_wkwebview
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- iOS中WKWebView白屏問(wèn)題的分析與解決
- Swift使用WKWebView在iOS應(yīng)用中調(diào)用Web的方法詳解
- iOS11 WKWebView 無(wú)法加載內(nèi)容的解決方法
- ios下OC與JS交互之WKWebView
- iOS11 WKWebView問(wèn)題匯總
- IOS中UIWebView、WKWebView之JS交互
- iOS和JS交互教程之WKWebView-協(xié)議攔截詳解
- iOS中WKWebView的一些特殊使用總結(jié)
- 簡(jiǎn)單說(shuō)說(shuō)iOS之WKWebView的用法小結(jié)
- iOs遷至WKWebView跨過(guò)的一些坑
相關(guān)文章
配置mac啟動(dòng)項(xiàng)的3種方式總結(jié)
這篇文章主要給大家介紹了關(guān)于配置mac啟動(dòng)項(xiàng)的3種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-02-02
詳解IOS開(kāi)發(fā)中圖片上傳時(shí)兩種圖片壓縮方式的比較
這篇文章主要介紹了IOS開(kāi)發(fā)中圖片上傳時(shí)兩種圖片壓縮方式的比較,需要的朋友可以參考下2017-03-03
iOS開(kāi)發(fā)中如何優(yōu)雅的調(diào)試數(shù)據(jù)庫(kù)詳解
這篇文章主要給大家介紹了關(guān)于iOS開(kāi)發(fā)中如何優(yōu)雅的調(diào)試數(shù)據(jù)庫(kù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12
iOS App的設(shè)計(jì)模式開(kāi)發(fā)中對(duì)State狀態(tài)模式的運(yùn)用
這篇文章主要介紹了iOS App的設(shè)計(jì)模式開(kāi)發(fā)中對(duì)State狀態(tài)模式的運(yùn)用,示例代碼為傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-03-03
IOS 出現(xiàn)問(wèn)題POST網(wǎng)絡(luò)請(qǐng)求狀態(tài)code:500的解決方法
這篇文章主要介紹了IOS 出現(xiàn)問(wèn)題POST網(wǎng)絡(luò)請(qǐng)求狀態(tài)code:500的解決方法的相關(guān)資料,需要的朋友可以參考下2017-02-02
IOS開(kāi)發(fā)中加載大量網(wǎng)絡(luò)圖片優(yōu)化方法
這篇文章主要介紹了IOS開(kāi)發(fā)中加載大量網(wǎng)絡(luò)圖片如何優(yōu)化的相關(guān)資料,需要的朋友可以參考下2017-03-03
iOS開(kāi)發(fā)使用GDataXML框架解析網(wǎng)絡(luò)數(shù)據(jù)
GDataXML是Google開(kāi)發(fā)的一個(gè)XML解析庫(kù),輕便,特點(diǎn)使用非常簡(jiǎn)單,支持XPath。今天把前兩天弄的IOS XML解析記錄下來(lái),也供大家參考。2016-02-02
iOS開(kāi)發(fā)中不合法的網(wǎng)絡(luò)請(qǐng)求地址如何解決
這篇文章主要介紹了iOS開(kāi)發(fā)中不合法的網(wǎng)絡(luò)請(qǐng)求地址的解決方案,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09

