WKWebView获取Javascript错误

时间:2018-05-08 09:06:56

标签: ios swift uiwebview wkwebview

有没有办法从Webview获取Javascript错误?我的意思是以下错误和可能的警告?

JS error

我使用以下扩展名

运行JS代码

```

extension WKWebView {
    func evaluateJavaScriptWithReturn(_ javaScriptString: String) -> String? {
        var finished = false
        var jsValue: String?

        evaluateJavaScript(javaScriptString) { (result, error) in
            if error == nil {
                if result != nil {
                    jsValue = result as? String
                }
            } else {
                jsValue = nil
            }
            finished = true
        }

        while !finished {
            RunLoop.current.run(mode: .defaultRunLoopMode, before: Date.distantFuture)
        }

        return jsValue
    }
}

```

error不是我想要的! 有没有办法进入我的应用程序,上述错误? 非常感谢!

4 个答案:

答案 0 :(得分:9)

要处理错误,我们将在加载到页面的HTML中添加一些JavaScript,这些HTML会将错误通知我们的本机代码。

首先,您需要使用脚本消息处理程序设置Web视图:

let controller = WKUserContentController()
controller.add(self, name: "error")

let configuration = WKWebViewConfiguration()
configuration.userContentController = controller

let webView = WKWebView(frame: .zero, configuration: configuration)

我在本地创建完整的HTML文档,并注入以下JavaScript:

window.onerror = (msg, url, line, column, error) => {
  const message = {
    message: msg,
    url: url,
    line: line,
    column: column,
    error: JSON.stringify(error)
  }

  if (window.webkit) {
    window.webkit.messageHandlers.error.postMessage(message);
  } else {
    console.log("Error:", message);
  }
};

(因为我有时会在浏览器中运行生成的JavaScript,所以我会进行检查并记录日志。)如果要将其注入HTML中,也可以使用WKUserContentController添加WKUserScript无法完全控制。

接下来,当您在网络视图中加载字符串时,请确保使用localhost作为基本URL 。如果您不这样做,那么所有错误都将是"Script error."

webView.loadHTMLString(html, baseURL: URL(string: "http://localhost/")!)

现在定义您的WKScriptMessageHandler

func userContentController(_ userContentController: WKUserContentController, didReceive message: WKScriptMessage) {
    switch message.name {
    case "error":
        // You should actually handle the error :)
        let error = (message.body as? [String: Any])?["message"] as? String ?? "unknown"
        assertionFailure("JavaScript error: \(error)")
    default:
        assertionFailure("Received invalid message: \(message.name)")
    }
}

您可以将其他情况添加到switch语句中,以添加到WKUserContentController的其他消息。

答案 1 :(得分:4)

尝试以下方式。

首先,注入JS代码以捕获html内容中的错误:

window.onerror = function(error) {
  alert(error); // Fire when errors occur. Just a test, not always do this.
};

第二次,在WKWebView委托方法中显示错误:

func webView(_ webView: WKWebView, runJavaScriptAlertPanelWithMessage message: String, initiatedByFrame frame: WKFrameInfo, completionHandler: @escaping () -> Void) {
    let alertController = UIAlertController(title: "alert", message: message, preferredStyle: UIAlertControllerStyle.alert)
    alertController.addAction(UIAlertAction(title: "OK", style: UIAlertActionStyle.cancel, handler: nil))
    self.present(alertController, animated: true, completion: nil)

    print("An error from web view: \(message)")
}

请记住设置委托:

webView.uiDelegate = self

如果您想避免提醒,另一种方法是使用decidePolicyForNavigationAction方法接收JS的回调,例如window.open("error://message","_self")

答案 2 :(得分:1)

我发现最好的解决方案是使用Safari的Web检查器。找到here的说明。

我一直使用陈云的解决方案(很棒)解决Script error.条消息,而没有任何可行的内容。

答案 3 :(得分:1)

在JavaScript中,钩上窗口onerror事件以回调脚本消息处理程序:

window.onerror = function (msg, url, line) {
    window.webkit.messageHandlers.mylog.postMessage("JS: ERROR:" + msg + " @" + url + ":" + line);
};

您可能只会收到“脚本错误”。消息,这是一个权限问题。 (documentation)根据您的设置,可以通过在首选项中添加权限来解决此问题。 斯威夫特:

webView.configuration.preferences.setValue(true, forKey: "allowFileAccessFromFileURLs")