先来唠叨几句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


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

  1. 在Eclipse中新建Android Project项目

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

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

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

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

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


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

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







更多相关文章

  1. Android通过Alpha实现渐变效果的几个方法
  2. Android的两种数据存储方式分析(二)
  3. 编程实现Android相机Camera设置
  4. android 上 webkit js 扩展之全局本地对象实现步骤
  5. Android实现录屏直播+远程控制之MediaCodec编码篇
  6. 进击的Android注入术《五》
  7. Android学习之五:android一些基本控件
  8. Android中使用输入提示
  9. 浅谈Java中Collections.sort对List排序的两种方法

随机推荐

  1. Android应用程序的Activity启动过程简要
  2. SlidingLayout
  3. Android 封装的数据库管理操作类
  4. android 图片处理
  5. ContentProvider(一)
  6. Android7.0中文API -- SeekBar
  7. 将android 应用强制横屏
  8. android TV开发常见问题
  9. 【Android】自定义 Tabhost
  10. Android HTTP框架Volley详解