iOS11中WKWebview得到了加强,添加了三种开发者呼声比较大的功能,分别是:
- Manage Cookie(Cookie 管理)
- Filter Unwanted Content (过滤不需要的内容)
- Provide Custom Resource (提供自定义的资源内容)
Manager Cookie
在iOS11前,要对Cookie进行管理只能在WKWebview初始化前自定义UserScript执行JS方法进行Cookie设置,代码大概如下:
WKWebViewConfiguration *webConfig = [[WKWebViewConfiguration alloc] init];
// 设置偏好设置
webConfig.preferences = [[WKPreferences alloc] init];
// 默认为0
webConfig.preferences.minimumFontSize = 10;
// 默认认为YES
webConfig.preferences.javaScriptEnabled = YES;
// 在iOS上默认为NO,表示不能自动通过窗口打开
webConfig.preferences.javaScriptCanOpenWindowsAutomatically = NO;
// web内容处理池
webConfig.processPool = [[WKProcessPool alloc] init];
// 将所有cookie以document.cookie = 'key=value';形式进行拼接
#warning 然而这里的单引号一定要注意是英文的,不要问我为什么告诉你这个(手动微笑)
NSString *cookieValue = @"document.cookie = 'fromapp=ios';document.cookie = 'channel=appstore';";
// 加cookie给h5识别,表明在ios端打开该地址
WKUserContentController* userContentController = WKUserContentController.new;
WKUserScript * cookieScript = [[WKUserScript alloc]
initWithSource: cookieValue
injectionTime:WKUserScriptInjectionTimeAtDocumentStart forMainFrameOnly:NO];
[userContentController addUserScript:cookieScript];
webConfig.userContentController = userContentController;
WKWebView *wkWebView = [[WKWebView alloc] initWithFrame:frame configuration:webConfig];
wkWebView.UIDelegate = wkWebView;
wkWebView.navigationDelegate = wkWebView;
但在iOS11中,WKWebview提供新的属性
let cookieStore = webView.configuration.websiteDataStore.httpCookieStore;
其提供的功能如下:
- Add and remove individual Cookies 添加删除指定的Cookie
- Access all cookies visible to a WKWebview 访问WKWebview的所有Cookies
- Including HTTP-Only Cookies
- Observer the cookie store for changes 观察Cookie Store的变化
添加Cookie
data:image/s3,"s3://crabby-images/9ea64/9ea645e8aab5f388530b3128dcae9f27ea2afcd0" alt=""
删除Cookie
data:image/s3,"s3://crabby-images/34acd/34acdca977b55d96e3b276e416214dff9fe58a8b" alt=""
遍历Cookie
data:image/s3,"s3://crabby-images/25ece/25ece59efe994a7d1caeda70d13fd05a2a281359" alt=""
Filter Unwanted Content
WKWebview实现内容过滤的方法和Safari的内容过滤扩展的方法类似,都是使用了ContentRuleList的东西,这个RuleList的主要功能有
- Block Loads 拦截加载
- Make Content Invisible 使内容不可见
- Make Insecure Loads Secure 使不安全的加载变得安全
使用时先把内容过滤的要求写成JSON格式
data:image/s3,"s3://crabby-images/2f07a/2f07aa8422a2e9f10f7be2305800598cb4a072d1" alt=""
然后调用WKContentRuleListStore的方法把它转为字节码
data:image/s3,"s3://crabby-images/03a74/03a7401a6767ef79983b3da8e3bc423ed73257bb" alt=""
这样WKWebview在加载内容时候会按照定义好的Rule去执行
可以通过以下方法遍历指定名字的RuleList
data:image/s3,"s3://crabby-images/9c1fd/9c1fdc2d3b440e9ce1e98a3040fa6d94a8af0e02" alt=""
Provide Custom Resource
在iOS11中,对于WKWebview可以注册指定的Scheme并设定回调对象,当WKWebview遇到这些指定的Scheme的请求,它会让回调对象处理这个请求,从而实现返回自定义的内容
注册Scheme
data:image/s3,"s3://crabby-images/23b62/23b62dc035b683cd2e4b2c81c1b15bdbaecb37a0" alt=""
Handler需要实现WKURLSchemeHandler协议
data:image/s3,"s3://crabby-images/b9274/b9274750fe6f5257ee12693e5500816652d584fd" alt=""
在协议中传入的参数都实现了WKURLSchemeTask协议
data:image/s3,"s3://crabby-images/493d8/493d861a3153db4dd14b9c3623ed2da773ba33d8" alt=""
返回自定义的内容
在WKURLSchemeHandler协议的实现方法中,一般都是取出Request信息,然后根据需求生成自定义的内容,再调用WKURLSchemeTask对象的didReceiveData和didReceiveResponse的方法等完成一个具体请求
data:image/s3,"s3://crabby-images/3c5a9/3c5a93970b0343e166801567e6f4dcd1ca692811" alt=""
网友评论