浅析App Webview与内嵌web实现交互

基于移动终端市场的火热和人手一机的时代,我也想着能够用Android开发一个手机app,要求不高,只需要首页嵌入至app内即可,点击内部链接采用默认手机浏览器打开即可。就纯粹地想引导一下用户,从而也从更多渠道获得用户的了解。 下面我就讲讲我是如何将web站点页面嵌入Android app内的。 一、Android开发环境部署 1、google一下“adt-bundle-windows-x86-20130917.zip”,然后下载下来进行解压过后就已经是一个eclipse和adt的一个整合IDE了的。 2、下载符合自己电脑版本的JDK进行安装。 3、接着是配置环境变量。 至于更多的Android环境部署请参考文章:Android开发入门教程...

几年前我自己做了一个web站点,如今人气还可以.基于移动终端市场的火热和人手一机的时代,我也想着能够用Android开发一个手机app,要求不高,只需要首页嵌入至app内即可,点击内部链接采用默认手机浏览器打开即可.就纯粹地想引导一下用户,从而也从更多渠道获得用户的了解.

实现的逻辑大体是这样的,APP webview 可以拦截请求的链接地址,通过与内嵌界面约定请求前缀(如:webjs2app:// ),后接请求内容。
请求内容如下:
  {"functionName":"sayHello',"args":["haha"],"success":"onSuccess","error":"onError"}
    是一个Json 字串,包括信息有调用的App 接口方法名、传的参数、调用成功后回调的js 方法名,调用失败后回调的js 方法名。抽象的很到位,可以做到通用。
    最终web 请求接口地址如:webjs2app://{"functionname":"sayHello',"args":["haha"],"success":"onSuccess","error":"onError"} App webview 收到由webjs2app:// 打头的请求地址时,就会把后面的请求内容解析出来。。。上代码。
      刚刚链接里面已经有IOS Web 的代码了,并且说明的明白。我这里补充一下Android 端对应的实现电脑维修
第一步,重写一下 shouldOverrideUrlLoading ,拦截约定的请求。
   private String protocolPrefix = "webjs2app://";  // 这个前缀要用小写,因为webview 会自动将请求协议类型转成小写的。
  mWebView.setWebViewClient(new WebViewClient() {
    @Override
    public boolean shouldOverrideUrlLoading(WebView view, String url) {
      return processURL(url);
    }
    。。。。
   }
第二步,解析请求接口数据
private boolean processURL(String url) {
int i = url.indexOf(protocolPrefix);
System.out.println(url);
if (url.indexOf(protocolPrefix) == 0) {
//strip protocol from the URL. We will getinput to call a native method
url =url.substring(protocolPrefix.length());
//Decode the url string
HashMap callInfo = JsonUtil.read(url,HashMap.class);
if (callInfo == null) {
//TODO: 提示调用解析失败
return false;
}
//Get function name. It is a required input
Object functionName =callInfo.get("functionName");
if (functionName == null) {
//TODO: 提示未找到调用方法
return false;
}
Object success =callInfo.get("success");
Object error =callInfo.get("error");
Object args =callInfo.get("args");
callNativeFunction((String) functionName,args, success, error);
return false;
}
return true;
}
第三步,利用java 反射,调用接口。
/**
* 方法接口调用
*
* @param functionName
* @param args
* @param success
* @param error
*/
private void callNativeFunction(StringfunctionName, Object args, Object success, Object error) {
try {
// 使用反射,注意不能对JsFunctions 类做混淆处理
Method method =JsFunctions.class.getMethod(functionName, WebView.class, Object.class,Object.class, Object.class);
Object invoke =method.invoke(JsFunctions.getInstance(),mWebView, args, success, error);
} catch (NoSuchMethodException e) {
//TODO: 提示未找到调用方法
} catch (InvocationTargetException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
//TODO: 提示权限访问
e.printStackTrace();
}
}
第四步,接口处理类
public class JsFunctions {
/**
* 单例
*/
private static JsFunctions instance = newJsFunctions();
/**
* sayHello 接口
* @param webView
* @param args
* @param successFunc
* @param errorFunc
*/
public void sayHello(WebView webView,Object args, Object successFunc, Object errorFunc) {
if (args != null) {
Object name = ((ArrayList) args).get(0);
Log.d(name.toString());
if (successFunc != null)
callJSFunction(webView,successFunc.toString(), args);
} else {
if (errorFunc != null)
callJSFunction(webView,errorFunc.toString(), args);
}
}
/**
* 回调处理
* @param webView
* @param functionName
* @param args
*/
public void callJSFunction(WebView webView,String functionName, Object args) {
String argsJsonStr = null;
if (args != null) {
argsJsonStr = JsonUtil.write2String(args);
}
if (argsJsonStr != null)
webView.loadUrl("javascript:" +functionName + "('" + argsJsonStr + "')");
else
webView.loadUrl("javascript:" +functionName + "()");
}
public static JsFunctions getInstance() {
return instance;
}
}
好了,就到这里,有什么不足请多多指正。。。当然,开发完 APP 也是需要进行全方位的检测:www.ineice.com
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值