3

我们的 iOS 应用程序从中读取 cookieWKHTTPCookieStore以调用初始化 Web 服务。如果我们要查找的特定 cookie 不存在于 CookieStore 中,则将在 web 服务中传递空值并返回相关响应。由于这是一个初始化 API,我们在完成处理程序中调用 web 服务,如下所示,并通过添加活动指示器来阻止 UI,直到它给出成功或失败。

WKWebsiteDataStore.default().httpCookieStore.getAllCookies { (cookies) in
            callInitializationService(cookies)
        }

在我们的测试中,它在从 iOS 11.3 到 12.2 的所有可用测试设备上运行良好。

当前的问题是生产应用程序有一个奇怪的行为,即活动指示器在安装后根本没有消失。我们发现根本原因是WKHTTPCookieStore.getAllCookies完成处理程序从未被调用,因此它阻塞了 UI。该问题主要在 iOS 11.2.x 操作系统版本中观察到,但不确定它是否也会影响任何其他操作系统版本。即使重新启动应用程序也不能解决问题。

有没有人遇到过这个问题?有什么解决方法/解决方法可以解决这个问题吗?

4

1 回答 1

5

自此更改以来,WebKitWKWebsiteDataStore直到必要时才进行初始化,这导致了有时在应该初始化时未初始化的问题。只有 Apple 才能修复的 bug 的真正来源。WKWebsiteDataStore在此之前,您可以在调用获取或设置 cookie 之后直接使用此解决方法来欺骗系统初始化:

if (@available(iOS 11.0, *)) {  
        // This completion handler won't be called for certain flows without the workaround below.
        [webView.configuration.websiteDataStore.httpCookieStore setCookie:cookie  
                                                        completionHandler:^{  
            [webView loadRequest:request];  
        }];  

        // WORKAROUND: Force the creation of the datastore by calling a method on it.  
        [webView.configuration.websiteDataStore fetchDataRecordsOfTypes:[NSSet<NSString *> setWithObject:WKWebsiteDataTypeCookies]  
                                                      completionHandler:^(NSArray<WKWebsiteDataRecord *> *records) {}];  
}

我在 hshamansky 写的答案中找到了这个解决方案。看起来原作者提交了一个错误报告,但看起来它似乎从未得到解决。苹果似乎很难重现这个问题。

于 2019-10-29T15:06:29.300 回答