js与native相互调用的那些事
1.native invoke js
2.js invoke native
无论是js invoke native还是native invoke js,都是要执行那块我们想执行的代码块。我们都知道想执行代码块我们可以通过方法名来执行。
在这里也是如此。
熟悉webview的都人知道native invoke js 简单,只要使用webview中的loadurl即可,例如:mWebview.loadUrl("javascript:方法名('参数')")。
不过js invoke native时就有点问题,这个问题就是在4.2之前使用addjavascriptInterface接口引起的安全问题。可以通过反射来恶意执行一些操作。
不过这个问题可以通过prompt方法进行解决。这里就是用的prompt方法来解决的,只不过需要和前端协商好一套协议。
还是如前面说的,无论是js invoke native还是native invoke js都是方法的调用,所以在js invoke native其实就是js和native交互的一个过程,js把需要执行的方法名、参数、类名告诉native,让native执行这个方法
而js和native交互,可以使用webviewclient中三个回调:onJsAlert()、onJsConfirm()、onPageprompt()中的Message来传递协议。
我们可以用一个url来包装这个协议,然后通过Uri获取到message中的类名、方法名、参数,最后通过反射来调用指定的方法。
1.native invoke js
2.js invoke native
无论是js invoke native还是native invoke js,都是要执行那块我们想执行的代码块。我们都知道想执行代码块我们可以通过方法名来执行。
在这里也是如此。
熟悉webview的都人知道native invoke js 简单,只要使用webview中的loadurl即可,例如:mWebview.loadUrl("javascript:方法名('参数')")。
不过js invoke native时就有点问题,这个问题就是在4.2之前使用addjavascriptInterface接口引起的安全问题。可以通过反射来恶意执行一些操作。
不过这个问题可以通过prompt方法进行解决。这里就是用的prompt方法来解决的,只不过需要和前端协商好一套协议。
还是如前面说的,无论是js invoke native还是native invoke js都是方法的调用,所以在js invoke native其实就是js和native交互的一个过程,js把需要执行的方法名、参数、类名告诉native,让native执行这个方法
而js和native交互,可以使用webviewclient中三个回调:onJsAlert()、onJsConfirm()、onPageprompt()中的Message来传递协议。
我们可以用一个url来包装这个协议,然后通过Uri获取到message中的类名、方法名、参数,最后通过反射来调用指定的方法。