您好,登錄后才能下訂單哦!
問題描述: iOS9和iOS10用WKWebView加載URL都沒有問題,iOS11卻是一片空白
可能是用了 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 的模擬器進(jìn)入Hybrid項目時,發(fā)現(xiàn)一進(jìn)去就崩潰,崩潰信息少的可憐:
libc++abi.dylib: terminating with uncaught exception of type NSException
靠這玩意兒肯定是定位不出bug的,不過全局?jǐn)帱c還是給出了一點信息:
- (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:
為了獲取一些堆棧信息以便于快準(zhǔn)狠的定位問題,可以在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í)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。