gpt4 book ai didi

ios - 在对 canInitWithRequest 的 YES 响应后,不要求加载 NSURLProtocol

转载 作者:行者123 更新时间:2023-11-29 12:35:43 26 4
gpt4 key购买 nike

我正在注册一个 NSURLProtocol 的实现来对某些 URL 请求进行一些自定义处理(我通过在它们上设置属性来标记这些请求)。这些 URL 请求来自 UIWebView 的加载方法。

  1. 创建 UI WebView (启动后首次加载)
  2. 加载内容
  3. 销毁 WebView
  4. 创建新的 WebView (后续加载)
  5. 加载内容

我发现第 2 步和第 5 步之间的行为有很大不同。我的 NSURLProtocol 实现管理缓存数据并设计用于处理请求。如果我没有在请求中检测到我的属性,我会再次检查特定的 URL(用于调试)。在任何一种情况下,canInitWithRequest 都将返回 YES:

启动后首次加载:

2014-10-15 11:37:11.403 MYApp[5813:60b] MYURLProtocol canInitWithRequest: Matched property in request: <0x15ebbb40> https://example.com/ 
2014-10-15 11:37:11.404 MYApp[5813:60b] MYURLProtocol canInitWithRequest: Matched property in request: <0x15dc8da0> https://example.com/
2014-10-15 11:37:11.409 MYApp[5813:60b] MYURLProtocol canInitWithRequest: Matched property in request: <0x15ee5ef0> https://example.com/
2014-10-15 11:37:11.409 MYApp[5813:60b] MYURLProtocol canInitWithRequest: Matched property in request: <0x15ee6240> https://example.com/
2014-10-15 11:37:11.410 MYApp[5813:60b] MYURLProtocol initWithRequest:cachedResponse:client: Request: https://example.com/
2014-10-15 11:37:11.411 MYApp[5813:60b] MYURLProtocol canInitWithRequest: Matched property in request: <0x15ee69d0> https://example.com/
2014-10-15 11:37:11.415 MYApp[5813:9c07] MYURLProtocol startLoading Loading <0x15ee6240> https://example.com/
... A bunch of loading of assets occurs (cached responses) ...
2014-10-15 11:37:12.497 MYApp[5813:60b] MyWebViewController webViewDidFinishLoad: Finished loading

其他人指出,针对同一个 Assets 多次调用协议(protocol),这不是问题,但有趣的是每次调用一个新对象时,它是第 4 个(的4) 传递给 startLoading 的对象。不过,这里没有真正的问题。

后续加载:

2014-10-15 11:11:27.466 MYApp[5782:60b] MYURLProtocol canInitWithRequest: Matched property in request: <0x1727c310> https://example.com/ 
2014-10-15 11:11:27.467 MYApp[5782:60b] MYURLProtocol canInitWithRequest: Matched property in request: <0x145b1d90> https://example.com/
2014-10-15 11:11:27.488 MYApp[5782:560f] MYURLProtocol canInitWithRequest: Matched URL in request: <0x17266060> https://example.com/
2014-10-15 11:11:27.669 MYApp[5782:60b] MYWebViewController webViewDidFinishLoad: Finished loading

在我看来,这是行为出乎意料的地方。似乎在第三次将属性传递给 canInitWithRequest 时,该属性已从请求中剥离,然后,即使我们响应 YES,我们也从未真正启动过 --该页面只是完整地返回到 UIWebView,没有后续的 Assets 请求。下面是创建请求时的样子:

NSURLRequest *request = [NSURLRequest requestWithURL:myURL cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:60.0];
[self.webView loadRequest:request];

为什么,当我说我的协议(protocol)可以处理请求时,它没有机会这样做吗?我的猜测是答案在于 UIWebView 本身的实现。如果我真的希望我的协议(protocol)成为负责加载的实体,有没有关于如何解决这个问题的想法?

最佳答案

*** Way to clear the cache of webview **********
Follow this code:

NSHTTPCookieStorage *storage = [NSHTTPCookieStorage sharedHTTPCookieStorage];
for (NSHTTPCookie *cookie in [storage cookies]) {
[storage deleteCookie:cookie];
}
[[NSUserDefaults standardUserDefaults] synchronize];

关于ios - 在对 canInitWithRequest 的 YES 响应后,不要求加载 NSURLProtocol,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26390036/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com