坦白讲应该是不难的,但本人不会js 所以开发起来有点难以下手 , 百度了很多的demo看了之后自己写完还是有问题 不知道什么情况 特来请教大家
我自己是在android平台写的
登陆地址: http://101.226.249.86:8080/jservice/#/SignIn (将这个地址用webview显示出来)
一.交互方式:
客户端网页中发起一个自定义url的请求,浏览器可以拦截到对应的请求;这一过程
相当于网页给Webview 发起了一个事件通知,其中自定义URL请求格式为:
ccn-webkit-bridge://xxx?functionName=xx
其中functionName参数是回调javascript函数的名字
接着webview中直接执行javascript函数,获取到对应的参数;
执行相关的native操作.
二.
客户端登录结束, 待服务器返回登录结果之后,执行如下的javascript代码
/**
该函数供 webkit 回调,返回 login 结果给 webkit
@return 注册 login 结果的 json 对象的字符串格式
**/
xxx() {
null
}
以上是人家给我的东西, 剩下都靠自己写
以下第一张图是登录页面,是一个webview, ,第二张是点击登录后的样子
附上自己的一部分代码 希望对答者有帮助,谢谢.
webView.loadUrl("http://101.226.249.86:8080/jservice/#/SignIn");
//启用支持javascript 加上这句话才能使用javascript方法
WebSettings settings = webView.getSettings();
settings.setJavaScriptEnabled(true);
//优先使用缓存
settings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);
webView.addJavascriptInterface(new MyJavaScriptInterface(), "getResult");
webView.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
//返回值是true的时候控制去WebView打开,为false调用系统浏览器或第三方浏览器
view.loadUrl(url);
return false;
}
});
//window.location.href = "ccn-webkit-bridge://did-login?functionName=getResult";
//webView.addJavascriptInterface(new Object(), "getResult");
所以,我感觉正确的流程是: