异常A WebView method was called on thread 'JavaBridge'. All WebView methods must be called on the same

在创建webview的另外一个地方调用webview加载网页,出现异常:

11-10 13:40:49.793: W/WebView(3684): java.lang.Throwable: A WebView method was called on thread 'JavaBridge'. All WebView methods must be called on the same thread. (Expected Looper Looper (main, tid 1) {52837448} called on Looper (JavaBridge, tid 250) {5289c660}, FYI main Looper is Looper (main, tid 1) {52837448})
11-10 13:40:49.793: W/WebView(3684): 	at android.webkit.WebView.checkThread(WebView.java:2072)
11-10 13:40:49.793: W/WebView(3684): 	at android.webkit.WebView.loadUrl(WebView.java:803)
11-10 13:40:49.793: W/WebView(3684): 	at com.leiting.sdk.channel.leiting.object.BaseObject.reload(BaseObject.java:251)
11-10 13:40:49.793: W/WebView(3684): 	at com.android.org.chromium.base.SystemMessageHandler.nativeDoRunLoopOnce(Native Method)
11-10 13:40:49.793: W/WebView(3684): 	at com.android.org.chromium.base.SystemMessageHandler.handleMessage(SystemMessageHandler.java:24)
11-10 13:40:49.793: W/WebView(3684): 	at android.os.Handler.dispatchMessage(Handler.java:102)
11-10 13:40:49.793: W/WebView(3684): 	at android.os.Looper.loop(Looper.java:136)
11-10 13:40:49.793: W/WebView(3684): 	at android.os.HandlerThread.run(HandlerThread.java:61)
11-10 13:40:51.377: W/System.err(3684): java.lang.RuntimeException: java.lang.Throwable: A WebView method was called on thread 'JavaBridge'. All WebView methods must be called on the same thread. (Expected Looper Looper (main, tid 1) {52837448} called on Looper (JavaBridge, tid 250) {5289c660}, FYI main Looper is Looper (main, tid 1) {52837448})
11-10 13:40:51.381: W/System.err(3684): 	at android.webkit.WebView.checkThread(WebView.java:2082)
11-10 13:40:51.381: W/System.err(3684): 	at android.webkit.WebView.loadUrl(WebView.java:803)
11-10 13:40:51.381: W/System.err(3684): 	at com.leiting.sdk.channel.leiting.object.BaseObject.reload(BaseObject.java:251)
11-10 13:40:51.381: W/System.err(3684): 	at com.android.org.chromium.base.SystemMessageHandler.nativeDoRunLoopOnce(Native Method)
11-10 13:40:51.381: W/System.err(3684): 	at com.android.org.chromium.base.SystemMessageHandler.handleMessage(SystemMessageHandler.java:24)
11-10 13:40:51.381: W/System.err(3684): 	at android.os.Handler.dispatchMessage(Handler.java:102)
11-10 13:40:51.385: W/System.err(3684): 	at android.os.Looper.loop(Looper.java:136)
11-10 13:40:51.385: W/System.err(3684): 	at android.os.HandlerThread.run(HandlerThread.java:61)
11-10 13:40:51.385: W/System.err(3684): Caused by: java.lang.Throwable: A WebView method was called on thread 'JavaBridge'. All WebView methods must be called on the same thread. (Expected Looper Looper (main, tid 1) {52837448} called on Looper (JavaBridge, tid 250) {5289c660}, FYI main Looper is Looper (main, tid 1) {52837448})
11-10 13:40:51.385: W/System.err(3684): 	at android.webkit.WebView.checkThread(WebView.java:2072)
11-10 13:40:51.385: W/System.err(3684): 	... 7 more
11-10 13:40:51.393: D/com.leiting.sdk(3684): mWebView WebChromeClientUncaught Error: Error calling method on NPObject.
11-10 13:40:51.393: I/chromium(3684): [INFO:CONSOLE(43)] "Uncaught Error: Error calling method on NPObject.", source: file:///android_asset/html/error.html (43)

分析:根据log日志可以看到是两个使用webview的地方不在同一个线程。

解决方案:

在另外的一个线程中使用webview的方法如下:

                view.post(new Runnable() {
			@Override
			public void run() {
				view.loadUrl(reloadUrl);
			}
		});





  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值