WWDC2017-Customized Loading in WKWebView

本文详细介绍了如何使用WKWebView在iOS11中加载本地资源,包括自定义URLScheme、设置URLSchemeHandler及提供图片和JS代码等资源的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

作者: iOS团队 - 高祥


官方链接: developer.apple.com/videos/play…


WKWebView在iOS11主要提供了一下三个功能:

  • Manage cookies(Cookie管理)
  • Filter unwanted content(过滤内容)
  • Provide custom resources(加载本地资源)

本文将详细介绍如何加载本地的资源(Image & JS)

示例工程项目在: 分支: Provide-Custom-resources


一、准备工作

  1. 新建一个工程,命名为wwdc2017-220-WKWebViewSimpleDemo

  2. 导入 WebKit

  3. 创建WKWebView,加载事先准备好的URL

    准备好的URL(后面要对这个html分析)
    http://oub5vvxvp.bkt.clouddn.com/customized_wkwebView.html
    复制代码

    运行起来,毛都没有? what? 出错了? 不不不,你需要在info.plist中添加ATS

    <key>NSAppTransportSecurity</key>
    <dict>
        <key>NSAllowsArbitraryLoads</key>
        <true/>
    </dict>
    
    复制代码

    好了,在运行一下,如果成下面这样,恭喜你,准备工作完成了。


二、自定义资源

自定义资源一共分为如下步骤:

  1. 自定义 URL Scheme
  2. 设置 URLSchemeHandler
  3. Provide custom resource(提供对应的资源)
2.1 自定义 URL Scheme

在上面的加载视图中,可以看到,图片未加载出来,而且点击按钮也是没有任何响应的. 在HTML中,定义了 img.src 和 js.src 为 URL Scheme

html代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
</head>
<body>
    <h3 id="photo"> 自定义图片:canineschool-avatar://photo  </h3>
    
    <!-- 注意 src -->
    ![](canineschool-avatar:///photo)
    <hr/ >
    
    <!-- 注意 src -->
    <script src="canineschool-avatar:///javascript">
    </script>
    
    <h3 id="javascript"> 自定义 JS 代码 canineschool-avatar://javascript </h3>

    <button type="button" onclick="myFunction()"> 点击这里 </button>

</body>
</html>
复制代码

关于URL Scheme我就不详细的去说了,不懂的话可以去参考URL Schemes 使用详解这篇文章。

值得指出的是,在html中配置的URL Scheme, 是不需要注册到info.plist URL Types的

2.2 设置 URLSchemeHandler

明确了需要处理的URL Scheme 之后,就需要一个“处理者”。 可以通过WKWebViewConfiguration来设置.

open func setURLSchemeHandler(_ urlSchemeHandler: WKURLSchemeHandler?, forURLScheme urlScheme: String)
复制代码

而其中: WKURLSchemeHandler 是一个自定义的协议

@available(iOS 11.0, *)
public protocol WKURLSchemeHandler : NSObjectProtocol {

    public func webView(_ webView: WKWebView, start urlSchemeTask: WKURLSchemeTask)

    public func webView(_ webView: WKWebView, stop urlSchemeTask: WKURLSchemeTask)
}
复制代码

好了,这些很明确了,我们需要一个对象,来遵循这个协议来,然后再协议定义的方法里面去处理. So Easy

自定义一个 Handler,遵循对应的协议

class MyURLSchemeHandler : NSObject, WKURLSchemeHandler {
    
    func webView(_ webView: WKWebView, start urlSchemeTask: WKURLSchemeTask) {
        
    }
    func webView(_ webView: WKWebView, stop urlSchemeTask: WKURLSchemeTask) {
        
    }
}
复制代码

改变WebView的初始化方式

let configuration = WKWebViewConfiguration()
        configuration.setURLSchemeHandler(MyURLSchemeHandler(), forURLScheme: "canineschool-avatar")
        
        let webView = WKWebView(frame: self.view.bounds, configuration: configuration)
复制代码

注意: 一个Handler 只能处理一个 URL Scheme

2.4 Provide custom resource(提供对应的资源)
  • 首先准备好资源

  • 在 WKURLSchemeHandler 的 start 中方法中处理URL Scheme

处理代码,仅参考

func webView(_ webView: WKWebView, start urlSchemeTask: WKURLSchemeTask) {
        
        let urlString = urlSchemeTask.request.url?.absoluteString ?? ""
        
        guard let type = URLSchemeType(rawValue: urlString) else {
            urlSchemeTask.didFailWithError(URLSchemeError.NotSupport(url: urlString))
            return
        }
        
        print(urlString)
        
        var response : URLResponse?
        var data : Data?
        
        switch type {
        case .Photo:
            guard let img = UIImage(named: "avatar"), let imageData = UIImagePNGRepresentation(img) else {
                return urlSchemeTask.didFailWithError(URLSchemeError.LackResource(url: urlString))
            }
            data = imageData
            response = URLResponse(url: urlSchemeTask.request.url!,
                                   mimeType: "image/png",
                                   expectedContentLength: imageData.count,
                                   textEncodingName: nil)
        case .Script:
            
            guard let path = Bundle.main.path(forResource: "alert.js", ofType: nil) else {
                return urlSchemeTask.didFailWithError(URLSchemeError.LackResource(url: urlString))
            }
            let fileURL = URL(fileURLWithPath: path)
            
            guard let scriptData = try? Data(contentsOf: fileURL) else  {
                return urlSchemeTask.didFailWithError(URLSchemeError.LackResource(url: urlString))
            }
            
            data = scriptData
            response = URLResponse(url: urlSchemeTask.request.url!,
                                   mimeType: "text/javascript",
                                   expectedContentLength:scriptData.count,
                                   textEncodingName: nil)
        }
        
        guard let receiveData = data,  let res = response else {
            return
        }
        urlSchemeTask.didReceive(res)
        urlSchemeTask.didReceive(receiveData)
        urlSchemeTask.didFinish()
    }
复制代码

处理对应的URL Scheme 需要注意如下几点:

1. 处理生成的 URLResponse 必须要有mimeType > mimeType类型可以在 developer.mozilla.org/zh-CN/docs/…

2.处理成功,必须要调用如下代码


// 告诉wkwebView 接收到了响应
urlSchemeTask.didReceive(res)
// 提供给webview对应的数据
urlSchemeTask.didReceive(receiveData)
// 告诉webView完成了
urlSchemeTask.didFinish()
复制代码
<think>嗯,用户想要下载定制化的ESXi 6.0标准版ISO镜像文件,具体是20170604001-standard版本。首先,我需要回忆一下ESXi的定制化ISO通常是如何生成的。根据之前提供的引用,比如引用[3]提到了ESXi-Customizer-PS这个工具,版本2.6.0,可以用来创建自定义的ESXi镜像。不过用户可能需要的是6.0版本,而ESXi-Customizer-PS可能支持不同的版本,需要确认兼容性。 接下来,用户提到的具体版本号是20170604001-standard,看起来像是一个构建版本。可能需要查看VMware的官方渠道或者知识库文章,比如引用[4]中有关于ESXi 6.0不支持设备的链接,但可能不直接提供下载链接。通常,VMware的官方ISO需要通过客户账户下载,但用户可能需要定制化的版本,这时候可能需要使用工具来集成补丁或驱动。 另外,引用[1]中的例子显示了一个定制化的ISO文件名,如ESXi-6.7.0-8169922-standard-customized.iso,说明定制化ISO通常会在文件名中加入“customized”标识。用户需要的是6.0版本,可能需要类似的命名方式,但需要确认是否存在对应的构建版本。 用户可能没有直接访问官方渠道的权限,或者希望找到第三方工具来生成。这时候需要推荐使用ESXi-Customizer-PS,并指导步骤。同时需要注意,VMware可能已停止对ESXi 6.0的官方支持,所以下载原版ISO可能需要旧版本的访问权限,而定制化则需要自己操作。 还需要提醒用户注意驱动兼容性,参考引用[4]中的不支持的设备清单,确保他们的硬件支持。此外,安全风险也需要提及,因为旧版本可能不再接收更新。 总结下来,回答应该包括官方下载途径(可能需要账户)、使用ESXi-Customizer-PS工具的步骤、验证校验和、驱动兼容性检查以及注意事项。同时生成相关问题,帮助用户进一步了解如何验证ISO、补丁集成方法、兼容性检查工具等。</think>根据您对ESXi 6.0定制版ISO的需求,以下是分步骤的解决方案: ### 一、获取定制化ISO的核心途径 1. **官方渠道构建** 需通过VMware客户账户登录[VMware Customer Connect](https://customerconnect.vmware.com),在「产品下载」中选择ESXi 6.0版本后: - 使用`ESXi-Customizer-PS`工具(支持Windows PowerShell)集成补丁/驱动[^3] - 执行命令示例: ```powershell .\ESXi-Customizer-PS-v2.6.0.ps1 -v60 -load net55-r8168,scsi-megaraid-sas ``` 2. **第三方工具构建** 通过开源项目[ESXi-Customizer](https://www.v-front.de/p/esxi-customizer.html)可实现: - 集成USB网卡驱动(如ASMedia ASM1074) - 添加NVMe驱动补丁(适用于老旧服务器) ### 二、关键验证步骤 1. **ISO校验** 原始ISO的SHA256值应与VMware KB 2143953公布的校验值匹配[^4] 2. **驱动兼容性** 需核实在ESXi 6.0不支持的设备清单中是否包含目标硬件,例如: - 2016年后发布的Intel i219网卡 - 部分NVMe PCIe 4.0设备[^4] ### 三、注意事项 1. **生命周期提醒** ESXi 6.0已于2020年3月终止主流支持,建议考虑升级到ESXi 7.0/8.0[^4] 2. **安全风险提示** 定制ISO可能包含第三方驱动程序,需从VMware Compatibility Guide验证供应商签名状态 $$ \text{ISO构建公式}:M_{\text{custom}} = M_{\text{base}} \oplus \sum_{i=1}^{n}(D_i + P_j) $$ (其中$D_i$为驱动程序,$P_j$为安全补丁)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值