使用 WKWebView 下载 PHP 生成的文件(iOS)

使用 wkwebview 下载 php 生成的文件(ios)

本文档旨在指导开发者在使用 WKWebView 加载 PHP 生成的文件时,如何在 iOS 应用中实现文件下载并保存到应用沙盒。针对 iOS 14.5 及以上版本,可以使用 WKDownloadDelegate 实现便捷下载。对于旧版本 iOS,则需要手动处理下载过程。本文将提供 Objective-C 代码示例,详细说明两种方案的实现方法,并提供相关注意事项。

iOS 14.5 及以上版本:使用 WKDownloadDelegate

自 iOS 14.5 起,WKWebView 引入了 WKDownloadDelegate,使得处理文件下载变得更加简单。以下是如何使用 WKDownloadDelegate 来下载 PHP 生成的文件:

设置 WKNavigationDelegate 和 WKDownloadDelegate:

首先,需要将 WKWebView 的 navigationDelegate 设置为自身,以便接收导航事件。同时,需要实现 WKDownloadDelegate 协议的方法。

立即学习“PHP免费学习笔记(深入)”;

- (void)viewDidLoad {    [super viewDidLoad];    self.webView = [[WKWebView alloc] initWithFrame:self.view.bounds];    self.webView.navigationDelegate = self;    NSURL* url = [NSURL URLWithString: @"https://your-domain.com/download.php"];    NSURLRequest* request = [NSURLRequest requestWithURL: url];    [self.webView loadRequest:request];    [self.view addSubview:self.webView];}

实现 decidePolicyForNavigationResponse 方法:

在此方法中,判断 navigationResponse 是否可以显示 MIME 类型。如果不能显示,则表示需要下载。

- (void)webView:(WKWebView *)webView decidePolicyForNavigationResponse:(nonnull WKNavigationResponse *)navigationResponse decisionHandler:(void (^)(WKNavigationResponsePolicy))decisionHandler {    if (navigationResponse.canShowMIMEType) {        decisionHandler(WKNavigationResponsePolicyAllow);    } else {        decisionHandler(WKNavigationResponsePolicyDownload);    }}

实现 navigationResponse:didBecomeDownload: 方法:

当导航响应触发下载时,此方法会被调用。在此处,需要将 download 的 delegate 设置为自身。

- (void)webView:(WKWebView *)webView navigationResponse:(WKNavigationResponse *)navigationResponse didBecomeDownload:(WKDownload *)download {    download.delegate = self;}

实现 download:decideDestinationUsingResponse:suggestedFilename:completionHandler: 方法:

此方法允许你决定下载文件的保存路径。在此处,你可以将文件保存到应用沙盒的 Documents 目录。

- (void)download:(WKDownload *)download decideDestinationUsingResponse:(NSURLResponse *)response suggestedFilename:(NSString *)suggestedFilename completionHandler:(void (^)(NSURL * _Nullable))completionHandler {    // Save to Documents    NSString *documentPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];    NSString *filePath = [documentPath stringByAppendingPathComponent:suggestedFilename];    NSURL* url = [NSURL fileURLWithPath:filePath];    completionHandler(url);}

实现 downloadDidFinish: 方法:

当下载完成时,此方法会被调用。可以在此处进行一些清理工作或通知用户下载完成。

- (void)downloadDidFinish:(WKDownload *)download {    // Downloaded}

iOS 14.5 之前版本:手动下载

对于 iOS 14.5 之前的版本,需要手动处理下载过程。以下是如何实现:

设置 WKNavigationDelegate:

与上述方法类似,需要将 WKWebView 的 navigationDelegate 设置为自身。

- (void)viewDidLoad {    [super viewDidLoad];    self.webView = [[WKWebView alloc] initWithFrame:self.view.bounds];    self.webView.navigationDelegate = self;    NSURL* url = [NSURL URLWithString: @"https://your-domain.com/download.php"];    NSURLRequest* request = [NSURLRequest requestWithURL: url];    [self.webView loadRequest:request];    [self.view addSubview:self.webView];}

实现 decidePolicyForNavigationResponse 方法:

在此方法中,判断 navigationResponse 是否可以显示 MIME 类型。如果不能显示,则发起手动下载。

- (void)webView:(WKWebView *)webView decidePolicyForNavigationResponse:(nonnull WKNavigationResponse *)navigationResponse decisionHandler:(void (^)(WKNavigationResponsePolicy))decisionHandler {    if (navigationResponse.canShowMIMEType) {        decisionHandler(WKNavigationResponsePolicyAllow);    }    else {        NSURL* downloadUrl = navigationResponse.response.URL;        NSURLSessionDataTask* dataTask = [NSURLSession.sharedSession dataTaskWithURL:downloadUrl completionHandler:^(NSData* data, NSURLResponse* response, NSError* error) {            if (data != nil) {                // Save to Documents                NSString *documentPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];                NSString *filePath = [documentPath stringByAppendingPathComponent:navigationResponse.response.suggestedFilename];                [data writeToFile:filePath atomically:YES];            }        }];        [dataTask resume];        decisionHandler(WKNavigationResponsePolicyCancel);    }}

在此方法中,我们使用 NSURLSessionDataTask 来下载文件。下载完成后,将数据保存到应用沙盒的 Documents 目录。注意,decisionHandler 需要设置为 WKNavigationResponsePolicyCancel,以阻止 WKWebView 加载该 URL。

注意事项

权限: 确保你的应用具有访问 Documents 目录的权限。错误处理: 在下载过程中,需要处理可能发生的错误,例如网络连接失败、文件写入失败等。线程: NSURLSessionDataTask 的 completionHandler 在后台线程执行,如果需要更新 UI,需要切换到主线程。文件名: navigationResponse.response.suggestedFilename 可能为空,需要进行判断和处理。

总结

本文档介绍了两种在使用 WKWebView 加载 PHP 生成的文件时,实现文件下载的方法。对于 iOS 14.5 及以上版本,可以使用 WKDownloadDelegate 实现便捷下载。对于旧版本 iOS,则需要手动处理下载过程。选择哪种方法取决于你的应用需要支持的 iOS 版本。希望本文档能帮助你解决相关问题。

以上就是使用 WKWebView 下载 PHP 生成的文件(iOS)的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1322346.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月12日 08:31:14
下一篇 2025年12月12日 08:31:21

相关推荐

发表回复

登录后才能评论
关注微信