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

聖光之護
发布: 2025-09-27 15:31:15
原创
433人浏览过

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

本文档旨在指导开发者如何在 iOS 应用中使用 WKWebView 下载由 PHP 脚本动态生成的文件。针对 iOS 14.5 及以上版本,我们将介绍利用 WKDownloadDelegate 实现下载并指定保存路径的方法。对于更早的 iOS 版本,则提供手动下载数据并保存的替代方案。

iOS 14.5 及以上版本:使用 WKDownloadDelegate

自 iOS 14.5 起,苹果引入了 WKDownloadDelegate,使得在 WKWebView 中处理文件下载变得更加方便。通过实现该代理,我们可以拦截下载请求,并指定文件的保存路径。

以下是一个完整的示例,展示了如何使用 WKDownloadDelegate 下载 PHP 生成的文件:

#import <WebKit/WebKit.h>

@interface ViewController : UIViewController <WKNavigationDelegate, WKDownloadDelegate>

@property (nonatomic, strong) WKWebView *webView;

@end

@implementation ViewController

- (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];
}

#pragma mark - WKNavigationDelegate

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

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

#pragma mark - WKDownloadDelegate

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

    completionHandler(url);
}

- (void)downloadDidFinish:(WKDownload *)download {
    // 下载完成
    NSLog(@"Download finished");
}

- (void)download:(WKDownload *)download didFailWithError:(NSError *)error resumeData:(NSData *)resumeData {
    // 下载失败
    NSLog(@"Download failed with error: %@", error);
}

@end
登录后复制

代码解释:

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

  1. 导入 WebKit: 引入必要的头文件 zuojiankuohaophpcnWebKit/WebKit.h>.
  2. 创建 WKWebView: 创建一个 WKWebView 实例,并设置其 navigationDelegate 为当前 ViewController。
  3. 加载 URL: 使用 loadRequest: 方法加载 PHP 脚本的 URL。
  4. decidePolicyForNavigationResponse:: 此方法判断是否允许导航响应。 如果 navigationResponse.canShowMIMEType 为真,则允许在 WebView 中显示内容。 否则,设置为 WKNavigationResponsePolicyDownload,表示这是一个下载请求。
  5. navigationResponse:didBecomeDownload:: 此方法在导航响应变成下载时被调用,设置 download.delegate 为当前 ViewController。
  6. download:decideDestinationUsingResponse:suggestedFilename:completionHandler:: 这是 WKDownloadDelegate 的核心方法。 在下载开始前,系统会调用此方法来确定下载文件的保存路径。 我们在此方法中获取 Documents 目录,并将文件名拼接成完整的路径,然后通过 completionHandler 将路径传递给系统。
  7. downloadDidFinish:: 下载完成时调用。
  8. download:didFailWithError:resumeData:: 下载失败时调用。

注意事项:

青鸟内测(手机app封装、托管系统)
青鸟内测(手机app封装、托管系统)

注意:请在linux环境下测试或生产使用 青鸟内测是一个移动应用分发系统,支持安卓苹果应用上传与下载,并且还能快捷封装网址为应用。应用内测分发:一键上传APP应用包,自动生成下载链接和二维码,方便用户内测下载。应用封装:一键即可生成app,无需写代码,可视化编辑、 直接拖拽组件制作页面的高效平台。工具箱:安卓证书生成、提取UDID、Plist文件在线制作、IOS封装、APP图标在线制作APP分发:

青鸟内测(手机app封装、托管系统) 0
查看详情 青鸟内测(手机app封装、托管系统)
  • 确保你的 Info.plist 文件中允许 App Transport Security (ATS) 豁免,以便允许加载非 HTTPS 的 URL (仅在开发阶段建议)。
  • suggestedFilename 可能为空,需要进行处理,例如生成一个随机文件名。
  • 需要处理下载失败的情况,并提供友好的错误提示。

iOS 14.5 之前版本:手动下载数据

对于 iOS 14.5 之前的版本,我们需要手动下载数据并保存到本地。 以下是一个示例:

#import <WebKit/WebKit.h>

@interface ViewController : UIViewController <WKNavigationDelegate>

@property (nonatomic, strong) WKWebView *webView;

@end

@implementation ViewController

- (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];
}

#pragma mark - WKNavigationDelegate

- (void)webView:(WKWebView *)webView decidePolicyForNavigationResponse:(nonnull WKNavigationResponse *)navigationResponse decisionHandler:(nonnull 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) {
                // 保存到 Documents 目录
                NSString *documentPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject];
                NSString *filePath = [documentPath stringByAppendingPathComponent:response.suggestedFilename];
                [data writeToFile:filePath atomically:YES];
                NSLog(@"File downloaded to: %@", filePath);
            } else {
                NSLog(@"Download failed with error: %@", error);
            }
        }];
        [dataTask resume];

        decisionHandler(WKNavigationResponsePolicyCancel);
    }
}

@end
登录后复制

代码解释:

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

  1. decidePolicyForNavigationResponse:: 与 iOS 14.5 及以上版本的实现类似,判断是否允许导航响应。
  2. 创建 NSURLSessionDataTask: 如果确定是下载请求,则创建一个 NSURLSessionDataTask 来下载文件。
  3. 下载数据: 在 completionHandler 中,将下载的数据保存到 Documents 目录。
  4. 取消导航: 使用 decisionHandler(WKNavigationResponsePolicyCancel) 取消 WebView 的导航,因为我们已经手动处理了下载。

注意事项:

  • 与 iOS 14.5 及以上版本类似,需要处理 suggestedFilename 为空的情况。
  • 需要处理下载失败的情况,并提供友好的错误提示。
  • 此方法在主线程中执行,如果下载的文件较大,可能会阻塞 UI。 可以考虑使用 GCD 将下载操作放到后台线程执行。

总结

本文档提供了两种在 WKWebView 中下载 PHP 生成文件的方法,分别适用于 iOS 14.5 及以上版本和之前的版本。 使用 WKDownloadDelegate 可以更方便地管理下载过程,而手动下载数据则提供了对旧版本 iOS 的兼容性。 在实际开发中,应根据目标 iOS 版本选择合适的方法,并注意处理各种异常情况,以提供良好的用户体验。

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

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号