先来唠叨几句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
在Eclipse中新建Android Project项目浏览器
把animesh kumar的websocket-android-phonegap项目java文件(WebSocketFactory.java和WebSocket.java)打成jar包,存放在 android project的libs目录下并导入工程websocket
把websocket.js存放在 assets/www/js目录下
修改项目启动类App.java
在App.java的onCreate方法中加入以下代码:
appView.addJavascriptInterface(new WebSocketFactory(appView), "WebSocketFactory");
添加<script src="js/websocket.js"></script>
必须注意的是这行必须在加载socket.io.js以前加载