問題描述: iOS9和iOS10用WKWebView加載URL都沒有問題,iOS11卻是一片空白
我們提供的服務(wù)有:網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、漣源ssl等。為上千余家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的漣源網(wǎng)站制作公司
可能是用了 NSMutableURLRequest ,iOS11貌似不支持 NSMutableURLRequest ,無論是用 UIWebView 還是 WKWebView ,都不支持 NSMutableURLRequest
解決方法參考
if #available(iOS 11, *) { let request = NSURLRequest.init(url: URL.init(string: urlStr)!) self.wkWebView.load(request as URLRequest) }else{ let request = NSMutableURLRequest.init(url: URL.init(string: urlStr)!, cachePolicy: NSURLRequest.CachePolicy.reloadIgnoringLocalAndRemoteCacheData, timeoutInterval: 60) request.httpMethod = "GET" request.httpBody = ("token=" + tokenValue()).data(using: String.Encoding.utf8) self.wkWebView.load(request as URLRequest) }
iOS11 Xcode9 WKWebView崩潰問題解決方案
正式版的iOS11&Xcode 9已經(jīng)發(fā)布,乘著版本空檔期,趕緊花點時間完成適配工作。
在用iPhone X 的模擬器進入Hybrid項目時,發(fā)現(xiàn)一進去就崩潰,崩潰信息少的可憐:
libc++abi.dylib: terminating with uncaught exception of type NSException
靠這玩意兒肯定是定位不出bug的,不過全局斷點還是給出了一點信息:
- (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler { NSString *requestString = navigationAction.request.URL.absoluteString; //對外鏈、撥號和跳轉(zhuǎn)appstore做特殊處理 UIApplication *app = [UIApplication sharedApplication]; NSURL *url = [navigationAction.request URL]; //電話 //此處省略若干業(yè)務(wù)代碼 if ([url.absoluteString containsString:@"itunes.apple.com"]) { if ([app canOpenURL:url]) { [app openURL:url]; decisionHandler(WKNavigationActionPolicyCancel); } } if ([requestString hasPrefix:@"easy-js:"]) { [self handleRequestString:requestString webView:(EasyJSWebView *)webView.superview]; decisionHandler(WKNavigationActionPolicyCancel); } if ([self.realDelegate respondsToSelector:@selector(webView:decidePolicyForNavigationAction:decisionHandler:)]) { [self.realDelegate webView:webView decidePolicyForNavigationAction:navigationAction decisionHandler:decisionHandler]; } decisionHandler(WKNavigationActionPolicyAllow);//崩在這里 }
仍然不知道為啥子崩在這兒?之前一直是沒問題的?。??
小Tips:
為了獲取一些堆棧信息以便于快準狠的定位問題,可以在main函數(shù)里:
int main(int argc, char * argv[]) { @try { @autoreleasepool { return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class])); } } @catch (NSException* exception) { NSDebugLog(@"Exception=%@\nStack Trace:%@", exception, [exception callStackSymbols]); } }
最終得到一條關(guān)鍵報錯:
Completion handler passed to -[WKPrivateNavigationDelegate webView:decidePolicyForNavigationAction:decisionHandler:] was called more than once
意思就是WKWebView的這個代理方法被多次調(diào)用了。
if ([requestString hasPrefix:@"easy-js:"]) { [self handleRequestString:requestString webView:(EasyJSWebView *)webView.superview]; decisionHandler(WKNavigationActionPolicyCancel); } if ([self.realDelegate respondsToSelector:@selector(webView:decidePolicyForNavigationAction:decisionHandler:)]) { [self.realDelegate webView:webView decidePolicyForNavigationAction:navigationAction decisionHandler:decisionHandler]; } decisionHandler(WKNavigationActionPolicyAllow);//崩在這里
簡單分析一下被多次調(diào)用的原因:
1、系統(tǒng)判斷這個方法被多次執(zhí)行,主要是看decisionHandler()是否被多次執(zhí)行;
2、由于if判斷里會執(zhí)行decisionHandler(),最后一行代碼也會執(zhí)行decisionHandler(),并且self.realDelegate中也會執(zhí)行decisionHandler(),這就導(dǎo)致了decisionHandler()這個handler可能會被多次執(zhí)行。
那解決問題的方向就是修改代碼保證WKWebView單次LoadRequest只調(diào)一次此代理方法~
修改如下:
if ([requestString hasPrefix:@"easy-js:"]) { [self handleRequestString:requestString webView:(EasyJSWebView *)webView.superview]; decisionHandler(WKNavigationActionPolicyCancel); } else if ([self.realDelegate respondsToSelector:@selector(webView:decidePolicyForNavigationAction:decisionHandler:)]) { [self.realDelegate webView:webView decidePolicyForNavigationAction:navigationAction decisionHandler:decisionHandler]; } else { decisionHandler(WKNavigationActionPolicyAllow); }
即保證了單次LoadRequest只執(zhí)行一次decisionHandler()
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。