在android的webview中实现websocket

   先来唠叨几句websocket,顾名思义,websocket也是socket,用来通讯的,只是用在web上,因此叫websocket。websocket是html5规范中的一项,在chrome、ff等主流浏览器中都已经支持。可是在咱们android的原生浏览器却……而android中的webview也是用的原生浏览器的核心,因此一样悲剧。html

   在websocket出现以后就有人开发了socket.io,这又是个啥呢?其实它就干了一个事,就是封装websocket,使得即便不支持websocket的平台在调用socket.io时也能正常通讯。并且在使用socket.io时,无论支不支持websocket,都只要一份代码就能够。
html5

   有了socket.io,咱们就能够在android环境的webview当中使用socket通讯了。可是,android并不支持websocket啊,socket.io究竟是怎么实现的socket通讯呢?原来socket.io会在平台不支持websocket的状况下使用其余的方式实现,好比:xhr、flashsocket。在android中,socket.io实现使用的就是xhr方式。
java

   xhr是实现了通讯,可是与websocket相比,xhr的实现方式性能上仍是不能比。那么有没有方式让android也实现真正的websocket呢?有,有人就想出了迂回的办法:android

   利用webview与页面能够相会调用的特性,采用JAVA NIO将websocket实现了一遍,这下可就是货真价实的socket了!
git


   其实已经有人实现了这种方式,并且只须要导入一些插件及修改极少的代码便可采用socket.io的代码在android的webview中实现websocket。
github

   项目github地址:https://github.com/koush/android-websockets#readmeweb


下面我简单讲一下使用方法:chrome

  1. 在Eclipse中新建Android Project项目浏览器

  2. 把animesh kumar的websocket-android-phonegap项目java文件(WebSocketFactory.java和WebSocket.java)打成jar包,存放在 android project的libs目录下并导入工程websocket

  3. 把websocket.js存放在 assets/www/js目录下

  4. 修改项目启动类App.java

    在App.java的onCreate方法中加入以下代码:

    appView.addJavascriptInterface(new WebSocketFactory(appView), "WebSocketFactory");


  5. 添加<script src="js/websocket.js"></script>

   必须注意的是这行必须在加载socket.io.js以前加载

相关文章
相关标签/搜索