WKWebView实战教程与示例

打印 上一主题 下一主题

主题 1043|帖子 1043|积分 3129

本文另有配套的精品资源,点击获取  

  简介:WKWebView是Apple公司为了提高iOS和macOS中网页展示性能、安全性和服从而设计的组件,它更换旧版UIWebView,提供当代渲染引擎和优化的内存管理。本教程将引导开发者了解WKWebView的基本使用方法,包括如何加载网页、实现JavaScript与原生代码的通信,以及如何处置惩罚网页进度和拦截。最后,通过  WKWebViewDemo  项目,我们将展示如何将这些技术要点运用于实践,创建一个可以大概加载和交互网页的iOS应用示例。
1. WKWebView组件概述

  WKWebView是苹果公司在iOS 8及OS X Mavericks中引入的一个新的网页视图组件,它取代了之前的UIWebView组件。作为开发者,我们使用WKWebView可以将Web内容嵌入到应用步伐中,让用户在不脱离应用的环境下浏览网页。与UIWebView相比,WKWebView在性能、安全性和用户体验方面都有明显提升,包括更快的渲染速度、更低的内存占用以及更好的沙箱机制等。此外,WKWebView提供了更加丰富的JavaScript接口,使原生应用与Web内容的交互变得更加顺畅。接下来的章节中,我们将详细介绍WKWebView组件的使用流程、性能与安全对比、JavaScript通信机制、隐私控制以及如何监控网页进度和拦截内容等核心功能。
2. WKWebView与UIWebView的性能和安全对比

  性能和安全是移动应用开发中两个极其关键的因素。当开发者评估使用哪种类型的Web视图组件时,这些因素尤其紧张。本章中,我们将探究WKWebView与旧版UIWebView在性能和安全两方面的对比,并详细分析各自的优缺点,帮助您做出更适合的选择。
2.1 性能对比

  性能对比主要关注WKWebView与UIWebView在现实应用中的响应速度、处置惩罚本领和资源占用环境。思量到用户对流通交互的高要求,我们从以下几个维度举行过细的分析。
2.1.1 渲染速度

  WKWebView在渲染速度上相比UIWebView有了明显的提升。其背后的核心技术包括Web内容的多进程架构和对最新Web技术标准的支持,这使得WKWebView可以更好地利用当代设备的硬件本领。
   代码示例:
  1. import WebKit
  2. // 初始化WKWebView
  3. let wkWebView = WKWebView(frame: .zero)
  4. let url = URL(string: "***")!
  5. let request = URLRequest(url: url)
  6. // 加载网页
  7. wkWebView.load(request)
复制代码
在这个示例中,我们初始化了一个  WKWebView  实例,并加载一个网页。这个过程中,  WKWebView  使用独立的进程举行网页内容的渲染,而不会壅闭主线程,从而提升渲染速度。
2.1.2 内存占用

  在内存管理方面,  WKWebView  同样表现优异。只管它对内存的需求略高于  UIWebView  ,但其优化后的架构能更有用管理内存使用,避免内存泄漏,而且在复杂的网页上保持了精良的性能。
   内存分析示例:
  为了测试内存占用,开发者可以使用Xcode自带的内存分析工具来对比在加载相同网页时,  WKWebView  和  UIWebView  的内存使用环境。通常,我们可以观察到  WKWebView  的内存使用更为高效,尤其是在处置惩罚大量JavaScript内容时。
2.2 安全对比

  在安全方面,  WKWebView  继续了Web内容沙箱机制,而且在JavaScript的实验环境上做了更多的安全控制,提升了整体的安全性。
2.2.1 沙箱机制

   WKWebView  采用了一种称为“沙箱”的机制,这是一种安全的架构模式,它将应用步伐的数据和文件限制在特定的隔离地区。当使用  WKWebView  时,你的应用和Web内容被分开,不能相互直接访问对方的资源。
   沙箱结构图:
  1. +--------------------------------+
  2. |          应用程序               |
  3. | +------------------------------+ |
  4. | |          WKWebView            | |
  5. | | +--------------------------+ | |
  6. | | | JavaScript环境           | | |
  7. | | +--------------------------+ | |
  8. | +------------------------------+ |
  9. +--------------------------------+
复制代码
在这个结构图中,我们可以看到,  WKWebView  运行在本身的环境内,这增强了安全性,由于Web内容无法直接访问设备上的敏感数据。
2.2.2 JavaScript实验环境

   WKWebView  对JavaScript实验环境的改进,进一步提升了应用的安全性。开发者可以更加精致地控制JavaScript代码的实验权限和访问限制,这在处置惩罚复杂的Web内容时尤其紧张。
   JavaScript实验权限控制示例:
  1. let wkWebView = WKWebView(frame: .zero)
  2. let javaScriptInjectionPolicy = WKContentRuleListStore.default().defaultList(for: .script)
  3. wkWebView.configuration.userContentController.add(javaScriptInjectionPolicy, name: "Script Injection Policy")
复制代码
在这个代码示例中,我们展示了如何添加一个脚本注入策略,通过这个策略可以限制  WKWebView  中JavaScript的实验,以防止潜伏的恶意脚本影响应用的安全性。
  总结而言,本章我们深入地探究了  WKWebView  与  UIWebView  在性能和安全方面的对比。通过实践测试和代码示例,我们了解了  WKWebView  如何在渲染速度和内存占用上有所优化,而且如何通过沙箱机制和JavaScript实验环境的改进,提升了应用的整体安全性。在接下来的章节中,我们将进一步学习  WKWebView  的配置和使用细节,以及如何实现更高级的功能,如JavaScript代码注入和安全通信。
3. WKWebView基本使用流程

3.1 配置WKWebView

3.1.1 初始化WKWebView

  WKWebView是iOS 8及以上版本提供的一个Web内容表现组件,它比之前的UIWebView提供了更好的性能和安全性。为了在你的应用中使用WKWebView,你需要首先对其举行初始化。
  初始化WKWebView的代码示例如下:
  1. import WebKit
  2. class ViewController: UIViewController {
  3.     var webView: WKWebView!
  4.     override func viewDidLoad() {
  5.         super.viewDidLoad()
  6.         // 初始化WKWebView
  7.         let configuration = WKWebViewConfiguration()
  8.         webView = WKWebView(frame: self.view.bounds, configuration: configuration)
  9.         self.view.addSubview(webView)
  10.         // 加载URL
  11.         if let url = URL(string: "***") {
  12.             let request = URLRequest(url: url)
  13.             webView.load(request)
  14.         }
  15.     }
  16. }
复制代码
3.1.2 设置代理和配置选项

  在初始化WKWebView之后,配置它的代理以及相关的选项是确保其按预期工作的关键步调。你需要遵守  WKNavigationDelegate  协议,以便在网页加载过程中吸取相关关照。
  设置代理和配置选项的代码示例如下:
  1. class ViewController: UIViewController, WKNavigationDelegate {
  2.     // ...
  3.     override func viewDidLoad() {
  4.         super.viewDidLoad()
  5.         // 设置WKWebView的代理
  6.         webView.navigationDelegate = self
  7.         // ...
  8.     }
  9.     // WKNavigationDelegate协议方法
  10.     func webView(_ webView: WKWebView, didStartProvisionalNavigation navigation: WKNavigation!) {
  11.         print("开始加载页面")
  12.     }
  13.     func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
  14.         print("页面加载完成")
  15.     }
  16.     // ...
  17. }
复制代码
3.2 导航和内容加载

3.2.1 加载网页

  加载网页是WKWebView基本使用流程中的核心功能。你可以使用  load  方法加载任何Web内容。加载时可以通报  URLRequest  对象来指定详细的网页地址。
  加载网页的代码示例如下:
  1. if let url = URL(string: "***") {
  2.     let request = URLRequest(url: url)
  3.     webView.load(request)
  4. }
复制代码
3.2.2 网页进步退却管理

  管理用户在浏览网页时的进步和退却操作是提供精良用户体验的关键部分。  WKWebView  提供了  goBack()  和  goForward()  方法,允许用户在浏览汗青中移动。
  进步退却管理的代码示例如下:
  1. // 后退到前一个页面
  2. if webView.canGoBack {
  3.     webView.goBack()
  4. }
  5. // 前进到后一个页面
  6. if webView.canGoForward {
  7.     webView.goForward()
  8. }
复制代码
3.1.1 初始化WKWebView

  在iOS应用开发中,为了展示网页内容,开发者经常会使用  UIWebView  ,但随着Apple推出  WKWebView  ,后者由于更好的性能和安全性,成为了推荐的方案。初始化  WKWebView  需要几个简单的步调:
  首先,需要导入  WebKit  框架:
  1. import WebKit
复制代码
然后,在  UIViewController  中声明一个  WKWebView  类型的变量,并在  viewDidLoad  方法中创建实在例:
  1. class ViewController: UIViewController {
  2.     var webView: WKWebView!
  3.     override func viewDidLoad() {
  4.         super.viewDidLoad()
  5.         // 初始化配置对象
  6.         let configuration = WKWebViewConfiguration()
  7.         // 创建WKWebView实例
  8.         webView = WKWebView(frame: self.view.bounds, configuration: configuration)
  9.         // 将webView添加到当前视图控制器的视图层级中
  10.         self.view.addSubview(webView)
  11.         // 加载指定的URL
  12.         if let url = URL(string: "***") {
  13.             let request = URLRequest(url: url)
  14.             webView.load(request)
  15.         }
  16.     }
  17. }
复制代码
在这段代码中,  WKWebView  被创建并添补了整个视图控制器的视图边界。然后通过  load  方法加载了  ***  这个URL的内容。
3.1.2 设置代理和配置选项

  为了充分利用  WKWebView  的高级功能,你需要设置代理并配置其选项。  WKWebView  的代理可以帮助你控制网页加载过程,好比拦截导航、处置惩罚网页内容以及配置用户界面元素。
  设置代理需要让  UIViewController  遵守  WKNavigationDelegate  协议,并设置为  WKWebView  实例的  navigationDelegate  :
  1. class ViewController: UIViewController, WKNavigationDelegate {
  2.     // ...
  3.     override func viewDidLoad() {
  4.         super.viewDidLoad()
  5.         // 初始化WKWebView和配置对象...
  6.         // 设置导航代理
  7.         webView.navigationDelegate = self
  8.     }
  9.     // 以下方法会在页面导航开始和结束时被调用
  10.     func webView(_ webView: WKWebView, didStartProvisionalNavigation navigation: WKNavigation!) {
  11.         // 页面开始加载时的操作
  12.     }
  13.     func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
  14.         // 页面加载完成时的操作
  15.     }
  16.     // ...
  17. }
复制代码
  WKWebView  的配置选项允许你根据需求自定义  WKWebView  的性能和行为,例如:
  1. let configuration = WKWebViewConfiguration()
  2. configuration.allowsInlineMediaPlayback = true
  3. configuration.mediaTypesRequiringUserActionForPlayback = .none
复制代码
上面的代码将允许网页中的视频自动播放,而不需要用户交互。
3.2.1 加载网页

  加载网页是  WKWebView  的最基本功能。你可以通过创建一个  URLRequest  对象来指定你渴望加载的网页地址,然后调用  load  方法:
  1. if let url = URL(string: "***") {
  2.     let request = URLRequest(url: url)
  3.     webView.load(request)
  4. }
复制代码
3.2.2 网页进步退却管理

  网页的进步退却功能对于用户来说非常紧张,它可以让用户在网页汗青中往返导航。  WKWebView  提供  canGoBack  和  canGoForward  属性来判定是否有汗青记载可以进步或退却,而且有  goBack  和  goForward  方法来现实实验进步或退却操作。
  1. if webView.canGoBack {
  2.     webView.goBack()
  3. }
  4. if webView.canGoForward {
  5.     webView.goForward()
  6. }
复制代码
在现实应用中,你可能会渴望在用户实验进步退却操作时,有相应的用户界面按钮大概动作响应,这时可以将上述代码绑定到相应的变乱处置惩罚函数上。
4. JavaScript代码注入与通信机制

4.1 JavaScript代码注入

4.1.1 在WKWebView中实验JavaScript

  WKWebView提供了强大的功能来实验JavaScript代码,这使得开发者可以在iOS应用中嵌入网页并与其交互。实验JavaScript代码通常用于网页内容的动态操作,如表单自动填写、数据获取以及实验网页中的自定义函数。
  1. func evaluateJavaScript(_ script: String, completionHandler: @escaping (Any?, Error?) -> Void) {
  2.     if let wkWebView = webView {
  3.         wkWebView.evaluateJavaScript(script) { (result, error) in
  4.             completionHandler(result, error)
  5.         }
  6.     }
  7. }
复制代码
在Swift代码中,  evaluateJavaScript  函数用于实验JavaScript代码。第一个参数是字符串情势的JavaScript代码,第二个参数是完成处置惩罚器,用于处置惩罚实验效果或错误。在完成处置惩罚器中,  result  参数将包罗JavaScript代码实验的效果,  error  参数则包罗可能发生的错误信息。
4.1.2 注入JavaScript的使用场景

  注入JavaScript的使用场景包括但不限于:


  • 自动填写登录表单
  • 动态修改网页元素样式
  • 从网页中提取数据
  在开发过程中,开发者需要根据现实业务需求判定何时实验JavaScript代码。例如,可以预先准备一段JavaScript代码来自动填写一个表单:
  1. var username = "username";
  2. var password = "password";
  3. document.getElementById('loginForm').elements['username'].value = username;
  4. document.getElementById('loginForm').elements['password'].value = password;
  5. document.getElementById('loginForm').submit();
复制代码
上面的JavaScript代码会添补一个具有ID为  loginForm  的表单,并提交该表单。在Swift中,可以将此代码作为字符串参数通报给  evaluateJavaScript  函数:
  1. evaluateJavaScript("var username = "username"; var password = "password"; document.getElementById('loginForm').elements['username'].value = username; document.getElementById('loginForm').elements['password'].value = password; document.getElementById('loginForm').submit();") { (result, error) in
  2.     if let error = error {
  3.         print("JavaScript execution error: \(error.localizedDescription)")
  4.     } else {
  5.         print("JavaScript executed successfully")
  6.     }
  7. }
复制代码
实验上述代码将模仿用户输入登录凭据,并尝试提交表单。
4.2 WKWebView与原生代码通信

4.2.1 使用evaluateJavaScript举行通信

  在iOS开发中,  evaluateJavaScript  不但可用于实验JavaScript,还可以用于处置惩罚WKWebView与原生代码之间的双向通信。这种通信机制使得开发者可以在JavaScript与Swift之间通报数据,实验相应的函数和响应用户界面的交互。
  以下是使用  evaluateJavaScript  举行通信的一个例子:
  1. func callNativeFromJavaScript() {
  2.     let jsFunction = "function() { window.webkit.messageHandlers.myHandler.postMessage('Hello from JavaScript!'); }"
  3.     let scriptSource = "var script = document.createElement('script'); script.textContent = '\(jsFunction)'; document.body.appendChild(script); script.remove();"
  4.     evaluateJavaScript(scriptSource) { (result, error) in
  5.         if let error = error {
  6.             print("Error calling JavaScript function: \(error.localizedDescription)")
  7.         }
  8.     }
  9. }
  10. // 在JavaScript中定义接收消息的处理程序
  11. // window.webkit.messageHandlers.myHandler是对原生代码中定义的handler的引用
复制代码
在Swift中,定义了一个JavaScript函数,并通过创建并实验一段脚本来实验这个函数。JavaScript函数通过  window.webkit.messageHandlers.myHandler.postMessage  发送消息到原生代码。
4.2.2 消息通报机制和回调函数

  为了处置惩罚从JavaScript传来的消息,开发者需要在WKWebView配置时注册一个消息处置惩罚器:
  1. let configuration = WKWebViewConfiguration()
  2. let userContentController = WKUserContentController()
  3. let messageHandler = WKScriptMessageHandler { (message) in
  4.     print("Received message from JavaScript: \(message.body)")
  5. }
  6. userContentController.add(messageHandler, name: "myHandler")
  7. configuration.userContentController = userContentController
  8. webView = WKWebView(frame: .zero, configuration: configuration)
复制代码
在Swift中,首先创建了一个  WKUserContentController  实例,然后添加了一个消息处置惩罚步伐,最后将这个控制器添加到  WKWebViewConfiguration  中。在JavaScript中,使用  postMessage  发送的消息会被  messageHandler  吸取,而且开发者可以在此中定义如何响应这个消息。
  这种机制允许开发者从JavaScript调用原生代码的方法,并从原生代码向JavaScript发送消息,实现了一个完整且流通的通信桥梁。通过这种方式,开发者可以根据需要设计自定义的通信协议,以适应复杂的应用场景。
  以上是第四章"JavaScript代码注入与通信机制"的详尽内容。在这个章节中,我们详细探究了如何在WKWebView中实验JavaScript代码,表明了使用场景,深入分析了JavaScript注入的紧张性。同时,我们也详细说明白WKWebView与原生代码通信的方式,包括使用  evaluateJavaScript  举行数据互换和处置惩罚消息通报机制以及回调函数的逻辑。通过实例和代码示例,本章向读者展示了如何在现实开发中应用这些技术,实现跨平台的通信和数据处置惩罚。
5. 网页进度监控和内容拦截功能

5.1 进度监控

5.1.1 监听网页加载进度

  在开发过程中,了解网页的加载状态对于提升用户体验至关紧张。WKWebView提供了监听网页加载进度的功能,从而可以实时跟踪加载过程并作出相应处置惩罚。进度信息是通过  WKNavigationDelegate  协议中的  didStartProvisionalNavigation  和  didCommitNavigation  方法来获得的。
  1. func webView(_ webView: WKWebView, didStartProvisionalNavigation navigation: WKNavigation!) {
  2.     print("开始加载")
  3. }
  4. func webView(_ webView: WKWebView, didCommitNavigation navigation: WKNavigation!) {
  5.     print("内容开始渲染")
  6. }
复制代码
从上述代码片段可以看出,通过实现  WKNavigationDelegate  协议中的两个方法,可以监测到加载的开始和提交阶段。使用这两个阶段,开发者可以更新UI元素,如进度条,以向用户表现加载状态。
5.1.2 使用进度条或指示器

  进度条或加载指示器是直观展示网页加载进度的UI组件,可以使用户对加载状态有直观的感知。在iOS中,可以通过  UIWebView  来设置自定义的进度条,但在  WKWebView  中需要结合  WKNavigationDelegate  来自定义进度条的实现。
  1. class ViewController: UIViewController, WKNavigationDelegate {
  2.     var webView: WKWebView!
  3.     var progressView: UIProgressView!
  4.     func setupWebView() {
  5.         let config = WKWebViewConfiguration()
  6.         webView = WKWebView(frame: .zero, configuration: config)
  7.         webView.navigationDelegate = self
  8.         progressView = UIProgressView(frame: CGRect(x: 0, y: 0, width: 0, height: 20))
  9.         // 更新进度条的值
  10.         webView.addObserver(self, forKeyPath: "estimatedProgress", options: .new, context: nil)
  11.     }
  12.     override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?) {
  13.         if keyPath == "estimatedProgress" {
  14.             progressView.progress = webView.estimatedProgress
  15.         }
  16.     }
  17.     override func viewDidLoad() {
  18.         super.viewDidLoad()
  19.         setupWebView()
  20.     }
  21. }
复制代码
在此代码段中,我们首先初始化了一个  UIProgressView  ,接着将  WKWebView  的  estimatedProgress  属性绑定到  UIProgressView  的  progress  属性上。当网页加载进度发生变革时,通过  KVO  (键值观察)机制更新进度条的进度。
5.2 内容拦截

5.2.1 拦截特定URL请求

  内容拦截通常是用来防止恶意网站或广告内容的加载。  WKWebView  允许开发者通过  WKNavigationDelegate  的  decidePolicyFor  方法来控制如何处置惩罚特定的URL请求。
  1. func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) {
  2.     if navigationAction.request.url?.absoluteString.lowercased().contains("ad") {
  3.         // 拦截包含"ad"的URL请求
  4.         decisionHandler(.cancel)
  5.     } else {
  6.         decisionHandler(.allow)
  7.     }
  8. }
复制代码
该代码段检测到请求的URL是否包罗"ad"字符串,如果是,则拦截该请求。这只是一个简单的示例,现实应用中可能需要更复杂的逻辑来判定是否拦截特定的请求。
5.2.2 拦截页面内特定内容

  在某些环境下,除了拦截特定的URL请求,还需要对页面内的内容举行拦截。例如,开发者可能需要移除页面上的特定广告元素。这可以通过  WKWebView  的JavaScript接口与JavaScript代码相结合来实现。
  1. // JavaScript代码片段
  2. const removeAds = () => {
  3.     const ads = document.querySelectorAll('.ad');
  4.     ads.forEach(ad => ad.remove());
  5. }
复制代码
然后,在  WKWebView  中注入这段JavaScript代码,实验后即可实现清除页面上的广告效果。
  1. webView.evaluateJavaScript("removeAds();", completionHandler: nil)
复制代码
需要留意的是,这种做法需要确保注入的JavaScript代码与页面内容完全兼容,且不破坏页面的原有功能。在实验复杂的DOM操作前,建议详细测试以确保功能的正确性和稳固性。
  以上所述展示了如何通过  WKWebView  举行网页加载进度的监控和内容拦截。监控进度可以提升用户体验,而内容拦截则对于提升应用性能和保障用户安全具有紧张作用。在现实开发中,开发者应结合详细需求,公道使用这些功能。
6. WKWebView隐私设置控制

  隐私保护已经成为移动应用开发中不可或缺的一部分,特别是在Web内容展示组件中。WKWebView提供了多个接口来控制隐私设置,确保用户数据的安全性。本章节深入探究WKWebView的隐私设置控制方法。
6.1 隐私设置基础

6.1.1 隐私相关API介绍

  WKWebView通过其API允许开发者对Web内容的加载和交互过程举行正确控制。在WKWebView中,有几个关键的隐私控制API,包括但不限于:


  •   setWebsiteDataStore:  - 设置WKWebView使用的网站数据存储,可以大概控制缓存、Cookie等的存储。
  •   setAllowsInlineMediaPlayback:  - 控制网页内的媒体是否可以在页面内播放。
  •   setAllowsArbitraryLoads:  - 控制WKWebView是否可以加载恣意的网页内容。
6.1.2 设置和获取Cookie

  在应用中管理用户会话和偏好设置时,经常需要对Cookie举行操作。WKWebView提供了一套API来设置和获取Cookie:


  •   WebsiteDataTypes  罗列了可以管理的数据类型,好比Cookie、缓存等。
  •   removeAllDataOfTypes:completionHandler:  方法可以用来清除存储在WKWebView中的Cookie。
  1. func clearCookies() {
  2.     let cookies = WKWebsiteDataStore.default().httpCookieStore.cookies
  3.     for cookie in cookies {
  4.         WKWebsiteDataStore.default().removeData(ofTypes: .cookie, matching: URL(string: "***")!, completionHandler: { })
  5.     }
  6. }
复制代码
在上述Swift代码中,我们获取了WKWebsiteDataStore中所有的Cookie,并对每一个Cookie实验了删除操作。调用  removeAllDataOfTypes:completionHandler:  方法后,传入  .cookie  作为类型参数来清除Cookie。
6.1.3 Cookie存储管理

  为了更好的管理Cookie,开发者可以选择自定义Cookie存储。例如,使用  NSHTTPCookieStorage  来控制应用级别的Cookie存储:
  1. let cookieStorage = HTTPCookieStorage.shared
  2. let cookies = cookieStorage.cookies ?? []
  3. for cookie in cookies {
  4.     if cookie.domain == "***" {
  5.         cookieStorage.deleteCookie(cookie)
  6.     }
  7. }
复制代码
这段Swift代码遍历并删除了所有来自特定域的Cookie。开发者也可以根据需要编写更复杂的逻辑,好比仅删除特定路径下的Cookie。
6.2 安全通信

6.2.1 开启HTTPS

  WKWebView默认只加载安全的HTTPS连接的网站内容。强制使用HTTPS可以有用减少中心人攻击和数据被窃听的风险。如果需要,开发者可以通过  WKPreferences  的  javaScriptCanOpenWindowsAutomatically  属性来控制JavaScript弹窗的行为,从而增强安全性。
6.2.2 证书验证和错误处置惩罚

  在处置惩罚HTTPS连接时,可能会遇到证书验证失败的环境。开发者可以通过实现  WKNavigationDelegate  的  webView:didReceiveAuthenticationChallenge:completionHandler:  方法来处置惩罚证书验证失败:
  1. func webView(_ webView: WKWebView, didReceive challenge: URLAuthenticationChallenge, completionHandler: @escaping (URLSession.AuthChallengeDisposition, URLCredential?) -> Void) {
  2.     if challenge.protectionSpace.authenticationMethod == NSURLAuthenticationMethodServerTrust {
  3.         if let serverTrust = challenge.protectionSpace.serverTrust {
  4.             let policy = SecTrustEvaluate(serverTrust, nil)
  5.             if policy == errSecSuccess {
  6.                 let credential = URLCredential(trust: serverTrust)
  7.                 completionHandler(.acceptCredential, credential)
  8.                 return
  9.             }
  10.         }
  11.     }
  12.     completionHandler(.rejectProtectionSpace, nil)
  13. }
复制代码
在这个示例中,我们通过  SecTrustEvaluate  函数评估服务器的信任,只有在验证乐成的环境下才继承证书,这增强了应用的网络安全。
6.2.3 安全通信实践

  要确保WKWebView的安全通信实践,开发者需要关注以下几个方面:


  • 升级到最新版本 :始终确保使用最新版本的WKWebView,以便获得最新的安全修复。
  • 依照最佳实践 :不要覆盖任何安全相关的设置,除非你有明确的理由和了解潜伏的安全风险。
  • 限制不安全资源加载 :可以通过限制不安全内容的加载来减少安全毛病。
6.3 隐私与用户体验的平衡

  在实验隐私设置的同时,还需要保证用户的精良体验。例如,不应该频繁清除用户数据,特别是用户渴望保存的数据,如登录凭据和偏好设置。这需要开发者在隐私保护和用户体验之间找到平衡点。
  1. graph TD
  2.     A[WKWebView隐私设置] --> B[Cookie管理]
  3.     A --> C[HTTPS强制]
  4.     A --> D[证书验证]
  5.     B --> E[设置和获取Cookie]
  6.     B --> F[清除Cookie]
  7.     C --> G[安全通信]
  8.     D --> H[证书错误处理]
  9.     E --> I[用户体验考量]
  10.     F --> I
  11.     G --> I
  12.     H --> I
复制代码
上述的mermaid流程图展示了如何从WKWebView隐私设置的角度出发,逐步深入到Cookie管理、HTTPS强制、证书验证和错误处置惩罚,最终到达在隐私保护与用户体验之间取得平衡的目的。
  总而言之,对WKWebView举行隐私设置控制是一个需要过细思量的过程。开发者需要充分利用苹果提供的API,确保应用既安全又尊重用户的隐私。同时,这种对隐私的尊重也是构建用户信任的关键因素。
7. WKWebViewDemo项目介绍

7.1 项目架构和设计

7.1.1 项目结构图解

  为了更好地明白  WKWebViewDemo  项目,首先让我们从其架构入手。下面是一个展示项目架构的图解:
  1. graph TD
  2.     A[WKWebViewDemo] --> B[ViewController]
  3.     B --> C[WKWebView]
  4.     C --> D[Web Page]
  5.     D --> E[JavaScript]
  6.     E --> F[Native Code]
复制代码
在上述图解中:


  •   ViewController  是用户界面与WKWebView交互的主要控制器。
  •   WKWebView  是核心组件,负责加载和渲染网页内容。
  •   Web Page  代表加载到WKWebView中的网页。
  •   JavaScript  是网页中可能实验的JavaScript代码。
  •   Native Code  指代与JavaScript举行交互的原生代码。
7.1.2 设计模式和最佳实践

  在  WKWebViewDemo  项目中,为了提升代码的可维护性和可扩展性,采用了模块化的设计模式。我们定义了以下几个关键模块:


  •   WebContentLoader  :负责加载网页内容。
  •   JavaScriptCommunicator  :管理WKWebView与JavaScript代码之间的通信。
  •   PageProgressMonitor  :监控网页加载进度和状态。
  •   ContentInterceptor  :拦截和处置惩罚网页内容。
  使用这些模块的目的是依照单一职责原则,每个模块都有明确的职责,易于明白和维护。
7.2 功能展示和代码解析

7.2.1 关键功能展示

  在  WKWebViewDemo  中,展示了以下关键功能:


  • 网页加载和导航 :加载指定URL的网页并提供进步、退却以及革新功能。
  • JavaScript与原生代码交互 :示例展示了如何在网页内调用原生代码以及反之亦然。
  • 进度条表现 :使用进度条展示当前网页加载状态。
  • 内容拦截 :演示了如何拦截特定URL请求和页面内内容。
7.2.2 核心代码剖析

  下面代码展示了如何初始化  WKWebView  并加载一个网页:
  1. class ViewController: UIViewController {
  2.     var webView: WKWebView!
  3.     override func viewDidLoad() {
  4.         super.viewDidLoad()
  5.         // 初始化WKWebView
  6.         let webConfiguration = WKWebViewConfiguration()
  7.         webView = WKWebView(frame: self.view.bounds, configuration: webConfiguration)
  8.         self.view.addSubview(webView)
  9.         // 加载网页
  10.         let url = URL(string: "***")!
  11.         let request = URLRequest(url: url)
  12.         webView.load(request)
  13.     }
  14. }
复制代码
在这段代码中,首先创建了一个  WKWebViewConfiguration  实例来配置  WKWebView  ,然后实例化  WKWebView  并将其添加到视图控制器的视图中。接下来创建一个  URLRequest  对象,并通过  load  方法加载网页。
  接下来的代码段展示了如何拦截URL请求:
  1. func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) {
  2.     if navigationAction.request.url?.scheme == "https" {
  3.         // 处理HTTPS请求
  4.         decisionHandler(.allow)
  5.     } else {
  6.         // 拦截非HTTPS请求
  7.         decisionHandler(.cancel)
  8.     }
  9. }
复制代码
在这里,  decidePolicyFor  方法用于拦截所有导航动作。如果请求的URL方案是  https  ,则允许请求继续;否则,将其取消。
  以上代码仅是对  WKWebViewDemo  项目中的部分功能举行了简要介绍和展示。在现实的项目中,还包罗了更多详细的实现细节和额外功能,以提高用户体验和应用的实用性。
   本文另有配套的精品资源,点击获取  

  简介:WKWebView是Apple公司为了提高iOS和macOS中网页展示性能、安全性和服从而设计的组件,它更换旧版UIWebView,提供当代渲染引擎和优化的内存管理。本教程将引导开发者了解WKWebView的基本使用方法,包括如何加载网页、实现JavaScript与原生代码的通信,以及如何处置惩罚网页进度和拦截。最后,通过  WKWebViewDemo  项目,我们将展示如何将这些技术要点运用于实践,创建一个可以大概加载和交互网页的iOS应用示例。
   本文另有配套的精品资源,点击获取  


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

反转基因福娃

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表