要在不知道URL的情况下从blob WKWebView下载图像,可以使用WKWebView的evaluateJavaScript方法来执行JavaScript代码,以获取图像的Base64编码。然后,可以使用此编码创建UIImage对象,并将其保存到设备上。
以下是一个示例的解决方案:
import WebKit
class ViewController: UIViewController, WKNavigationDelegate {
var webView: WKWebView!
override func viewDidLoad() {
super.viewDidLoad()
// 创建WKWebView
let configuration = WKWebViewConfiguration()
webView = WKWebView(frame: view.bounds, configuration: configuration)
webView.navigationDelegate = self
view.addSubview(webView)
// 加载HTML页面
let html = """
"""
webView.loadHTMLString(html, baseURL: nil)
}
func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
// 通过执行JavaScript代码获取图像的Base64编码
webView.evaluateJavaScript("document.getElementById('myImage').src", completionHandler: { (result, error) in
if let imageUrl = result as? String {
let base64Data = imageUrl.replacingOccurrences(of: "data:image/jpeg;base64,", with: "")
if let imageData = Data(base64Encoded: base64Data) {
// 创建UIImage对象
if let image = UIImage(data: imageData) {
// 将图像保存到设备上
if let documentsDirectory = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first {
let fileUrl = documentsDirectory.appendingPathComponent("myImage.jpg")
try? imageData.write(to: fileUrl)
print("图像已保存:\(fileUrl)")
}
}
}
}
})
}
}
在此示例中,我们创建一个WKWebView,并加载包含图像的HTML字符串。在webView的didFinish回调中,我们执行JavaScript代码来获取图像的Base64编码。然后,我们将Base64编码转换为Data对象,并创建一个UIImage对象。最后,我们将图像保存到设备上,可以根据需要修改保存路径和文件名。