在同一个线程错误的WebView方法线程、错误、方法、在同一个

2023-09-05 07:45:43 作者:沫忆

我有一个Android程序(Java的+ HTML的web视图)。我可以从JavaScript来了Java code调用。但周围的其他方法停止工作(在Eclipse更新后)。

这就是我想要做的。

请一个的WebView(工作) 调用javascript来AndroidFunction.test(); (工作) 的Java测试()函数调用webView.loadUrl(JavaScript的:helloBack()); (!不工作了)

我试图让他跟在MainActivity web视图的工作,但没有工作。

MainActivity.java

 公共无效的onCreate(包savedInstanceState){
        super.onCreate(savedInstanceState);
        的setContentView(R.layout.main);
        最后的WebView web视图=(web视图)findViewById(R.id.webView);
        webView.getSettings()setJavaScriptEnabled(真)。
        webView.setWebChromeClient(新WebChromeClient());
        WebSettings webSettings = webView.getSettings();
        webSettings.setJavaScriptEnabled(真正的);

        javascr =新的Javascript(这一点,web视图);
        webView.addJavascriptInterface(javascrAndroidFunction);
        webView.loadUrl(文件:///android_asset/www/index.html);

        ....
}
 

Javascript.java

 公共类的Javascript {
    语境续;
    的WebView web视图;

    使用Javascript(上下文C,的WebView W){
        CONT = C;
        web视图= W;
    }

    //函数通过AndroidFunction.test()调用的JavaScript;
    公共无效测试(){
          // 突破点!!!
        webView.loadUrl(JavaScript的:helloBack());
    }
 

错误:

  11月三号至24号:47:50.103:W /的WebView(21026):在com.android.org.chromium.base.SystemMessageHandler.handleMessage(SystemMessageHandler.java:27)
11月3日至24号:47:50.103:W /的WebView(21026):java.lang.Throwable中:一个的WebView方法被调用的线程JavaBridge的。所有的WebView方法必须调用在同一个线程。 (预期活套活套{41ab68f8}呼吁尺蠖{41bb70a8},仅供参考主尺蠖是活套{41ab68f8})

11月3日至24号:47:50.103:W /的WebView(21026):在android.webkit.WebView.checkThread(WebView.java:2063)
11月3日至24号:47:50.103:W /的WebView(21026):在android.webkit.WebView.loadUrl(WebView.java:794)
11月3日至24号:47:50.103:W /的WebView(21026):在com.example.hellobt.Javascript.test(Javascript.java:24)

11月3日至24号:47:50.103:W /的WebView(21026):在com.android.org.chromium.base.SystemMessageHandler.nativeDoRunLoopOnce(本机方法)
11月3日至24号:47:50.103:W /的WebView(21026):在com.android.org.chromium.base.SystemMessageHandler.handleMessage(SystemMessageHandler.java:27)
11月3日至24号:47:50.103:W /的WebView(21026):在android.os.Handler.dispatchMessage(Handler.java:102)

11月3日至24号:47:50.103:W /的WebView(21026):在android.os.Looper.loop(Looper.java:137)
11月3日至24号:47:50.103:W /的WebView(21026):在android.os.HandlerThread.run(HandlerThread.java:61)
 
线程的安全问题 临界资源的解释 ,以及如何使线程安全 同步 方法

感谢您的回答。我在我的JavaScript文件这样的编辑功能:

 私人无效测试(最终的String){
        webView.post(新的Runnable(){
            公共无效的run(){
                webView.loadUrl(JavaScript的:+ S +;);
            }
        });
        的System.out.println(javscript做..);
    }
 

解决方案

JavaScript的方法是在后台执行(即非UI)线程。你需要调用所有的UI线程在Android上查看相关的方法。您可以实现您需要什么:

  mWebView.post(新的Runnable(){
    @覆盖
    公共无效的run(){
        mWebView.loadUrl(...)。
    }
});
 

这将张贴到UI线程上运行的任务。

I have a android program (Java + html in a webview). I can call from the javascript to the Java code. But the other way around stopped working (after updating in eclipse).

So this is what I'm trying to do

Make a webview (worked) calling in javascript to AndroidFunction.test(); (worked) the java test() function call webView.loadUrl("javascript:helloBack()"); (! not working anymore)

I tried to let it work with the WebView in the MainActivity, but it didnt work.

MainActivity.java

public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        final WebView webView = (WebView)findViewById(R.id.webView);
        webView.getSettings().setJavaScriptEnabled(true);
        webView.setWebChromeClient(new WebChromeClient());
        WebSettings webSettings = webView.getSettings();
        webSettings.setJavaScriptEnabled(true);

        javascr = new Javascript(this, webView);
        webView.addJavascriptInterface(javascr, "AndroidFunction");
        webView.loadUrl("file:///android_asset/www/index.html");

        ....
}

Javascript.java

public class Javascript {   
    Context cont;
    WebView webView;

    Javascript(Context c, WebView w) {
        cont = c;
        webView = w;
    }

    // function called in the javascript by AndroidFunction.test();
    public void test() {
          // Breaking point!!!
        webView.loadUrl("javascript:helloBack()");
    }

Error:

03-24 11:47:50.103: W/WebView(21026):   at com.android.org.chromium.base.SystemMessageHandler.handleMessage(SystemMessageHandler.java:27)
03-24 11:47:50.103: W/WebView(21026):   java.lang.Throwable: A WebView method was called on thread 'JavaBridge'. All WebView methods must be called on the same thread. (Expected Looper Looper{41ab68f8} called on Looper{41bb70a8}, FYI main Looper is Looper{41ab68f8})

03-24 11:47:50.103: W/WebView(21026):   at android.webkit.WebView.checkThread(WebView.java:2063)
03-24 11:47:50.103: W/WebView(21026):   at android.webkit.WebView.loadUrl(WebView.java:794)
03-24 11:47:50.103: W/WebView(21026):   at com.example.hellobt.Javascript.test(Javascript.java:24)

03-24 11:47:50.103: W/WebView(21026):   at com.android.org.chromium.base.SystemMessageHandler.nativeDoRunLoopOnce(Native Method)
03-24 11:47:50.103: W/WebView(21026):   at com.android.org.chromium.base.SystemMessageHandler.handleMessage(SystemMessageHandler.java:27)
03-24 11:47:50.103: W/WebView(21026):   at android.os.Handler.dispatchMessage(Handler.java:102)

03-24 11:47:50.103: W/WebView(21026):   at android.os.Looper.loop(Looper.java:137)
03-24 11:47:50.103: W/WebView(21026):   at android.os.HandlerThread.run(HandlerThread.java:61)

Thanks for the answer. I edited the function in my Javascript file like this:

private void test(final String s) {
        webView.post(new Runnable() {
            public void run() {
                webView.loadUrl("javascript:" + s + ";");
            }
        });
        System.out.println("javscript done..");
    }

解决方案

The JavaScript method is executed on a background (i.e. non-UI) thread. You need to call all Android View related methods on the UI thread. You can achieve what you need with:

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

Which will post the task to run on the UI thread.