先来唠叨几句websocket,顾名思义,websocket也是socket,用来通信的,只是用在web上,所以叫websocket。websocket是html5规范中的一项,在chrome、ff等主流浏览器中都已经支持。但是在我们android的原生浏览器却……而android中的webview也是用的原生浏览器的核心,所以同样悲剧。
在websocket出现之后就有人开发了socket.io,这又是个啥呢?其实它就干了一个事,就是封装websocket,使得即使不支持websocket的平台在调用socket.io时也能正常通信。而且在使用socket.io时,不管支不支持websocket,都只要一份代码就可以。
有了socket.io,我们就可以在android环境的webview当中使用socket通信了。但是,android并不支持websocket啊,socket.io到底是怎么实现的socket通信呢?原来socket.io会在平台不支持websocket的情况下使用其他的方式实现,比如:xhr、flashsocket。在android中,socket.io实现使用的就是xhr方式。
xhr是实现了通信,但是与websocket相比,xhr的实现方式性能上还是不能比。那么有没有方式让android也实现真正的websocket呢?有,有人就想出了迂回的办法:
利用webview与页面可以相会调用的特性,采用JAVA NIO将websocket实现了一遍,这下可就是货真价实的socket了!
其实已经有人实现了这种方式,而且只需要导入一些插件及修改极少的代码即可采用socket.io的代码在android的webview中实现websocket。
项目github地址:
https://github.com/koush/android-websockets#readme
下面我简单讲一下使用方法:
-
在Eclipse中新建Android Project项目
-
把animesh kumar的websocket-android-phonegap项目java文件(WebSocketFactory.java和WebSocket.java)打成jar包,存放在 android project的libs目录下并导入工程
-
把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之前加载