Android通讯-webSocket
概述
上一篇简单的认识了Socket以及他的使用,在学习过程中看到了WebSocket的身影,于是乎百度了一把,这货也可以做全双工的网络通讯,而且是html5提出来的新东西!程序员嘛!就是要对新的东西充满了好奇!
WebSocket
引用API里面的一句话,WebSocket是HTML5开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。
全双工:简单理解为C,S端可以相互发送和接收数据。
WebSocket和Socket之间有啥关系?
答:李鬼和李逵的关系,他只是名字上带有Socket,他是同Http一样使用TCP协议来传输数据的,但是和Http最大的不同就是他是全双工的。
还不明白的话看下面的解释。
WebSocket 协议本质上是一个基于 TCP 的协议。
为了建立一个 WebSocket 连接,客户端浏览器首先要向服务器发起一个 HTTP 请求,这个请求和通常的 HTTP 请求不同,包含了一些附加头信息,其中附加头信息”Upgrade: WebSocket”表明这是一个申请协议升级的 HTTP 请求,服务器端解析这些附加的头信息然后产生应答信息返回给客户端,客户端和服务器端的 WebSocket 连接就建立起来了,双方就可以通过这个连接通道自由的传递信息,并且这个连接会持续存在直到客户端或者服务器端的某一方主动的关闭连接。
他首先是在Html5中被提出来的,使用javaScript与服务端建立全双工通道。但是这套思想也有人做出了jar包提供给java使用。
我们先来看下在Html中他是如何使用的。
在Html中的使用
要注意有些浏览器现在还不支持WebSocket,我们先用Chrom测试。
占坑
在Android中的使用(Android 聊天室)
先看下效果吧,下面代码太多了,不过很简单,就不放源码下载地址了。
思路就是,一个服务端转发消息,多个移动端接收消息。
Android端代码
1 引入java-WebSocket依赖包
在module/build.gradle 中
//WebSocket 依赖包
compile 'org.java-websocket:Java-WebSocket:1.3.0'
别忘了在AndroidManifest.xml 中加上网络权限
<uses-permission android:name="android.permission.INTERNET" />
2 逻辑代码
public class WebSocketActivity extends AppCompatActivity {
@Bind(R.id.m_content_et)
EditText mContentEt;
@Bind(R.id.m_sent_bt)
Button mSentBt;
@Bind(R.id.m_content_tv)
TextView mContentTv;
private WebSocketClient mSocketClient;
private Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
mContentTv.setText(mContentTv.getText() + "\n" + msg.obj);
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_web_socket);
ButterKnife.bind(this);
init();
}
private void init() {
new Thread(new Runnable() {
@Override
public void run() {
try {
//TODO 这里URL 别忘了切换到自己的IP
mSocketClient = new WebSocketClient(new URI("ws://10.27.0.197:2017/"), new Draft_10()) {
@Override
public void onOpen(ServerHandshake handshakedata) {
Log.d("picher_log", "打开通道" + handshakedata.getHttpStatus());
handler.obtainMessage(0, message).sendToTarget();
}
@Override
public void onMessage(String message) {
Log.d("picher_log", "接收消息" + message);
handler.obtainMessage(0, message).sendToTarget();
}
@Override
public void onClose(int code, String reason, boolean remote) {
Log.d("picher_log", "通道关闭");
handler.obtainMessage(0, message).sendToTarget();
}
@Override
public void onError(Exception ex) {
Log.d("picher_log", "链接错误");
}
};
mSocketClient.connect();
} catch (URISyntaxException e) {
e.printStackTrace();
}
}
}).start();
mSentBt.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (mSocketClient != null) {
mSocketClient.send(mContentEt.getText().toString().trim());
}
}
});
}
@Override
protected void onDestroy() {
super.onDestroy();
if (mSocketClient != null) {
mSocketClient.close();
}
}
}
这就好了,很简单,接下来看下服务端的代码写法
服务端代码
1 引入jar包
去下载jar,获取自己配maven
https://mvnrepository.com/artifact/org.java-websocket/Java-WebSocket/1.3.0
2 编写WebSocketServer
public class MWebSocketService extends WebSocketServer {
public MWebSocketService(int port) throws UnknownHostException {
super(new InetSocketAddress(port));
}
public MWebSocketService(InetSocketAddress address) {
super(address);
}
@Override
public void onOpen(WebSocket webSocket, ClientHandshake clientHandshake) {
String address = webSocket.getRemoteSocketAddress().getAddress().getHostAddress();
String message = String.format("(%s) <进入房间!>", address);
sendToAll(message);
System.out.println(message);
}
@Override
public void onClose(WebSocket webSocket, int i, String s, boolean b) {
String address = webSocket.getRemoteSocketAddress().getAddress().getHostAddress();
String message = String.format("(%s) <退出房间!>", address);
sendToAll(message);
System.out.println(message);
}
@Override
public void onMessage(WebSocket webSocket, String s) {
//服务端接收到消息
String address = webSocket.getRemoteSocketAddress().getAddress().getHostAddress();
String message = String.format("(%s) %s", address, s);
//将消息发送给所有客户端
sendToAll(message);
System.out.println(message);
}
private static void print(String msg) {
System.out.println(String.format("[%d] %s", System.currentTimeMillis(), msg));
}
@Override
public void onError(WebSocket webSocket, Exception e) {
if (null != webSocket) {
webSocket.close(0);
}
e.printStackTrace();
}
public void sendToAll(String message) {
// 获取所有连接的客户端
Collection<WebSocket> connections = connections();
//将消息发送给每一个客户端
for (WebSocket client : connections) {
client.send(message);
}
}
}
3 编写main方法
public class WebSocketMainMethod {
private static int PORT = 2017;
public static void main(String[] args) throws IOException {
MWebSocketService socketServer = new MWebSocketService(PORT);
socketServer.start();
try {
String ip = InetAddress.getLocalHost().getHostAddress();
int port = socketServer.getPort();
System.out.println(String.format("服务已启动: %s:%d", ip, port));
} catch (UnknownHostException e) {
e.printStackTrace();
}
InputStreamReader in = new InputStreamReader(System.in);
BufferedReader reader = new BufferedReader(in);
while (true) {
try {
String msg = reader.readLine();
socketServer.sendToAll(msg);
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
OK,看下成果图!
其他
在学习的过程中也发现了不少别人封装好的库,也记录进来吧
以下内容转自 android中使用webSocket通信
1.AndroidAsyn
GitHub地址:https://github.com/koush/AndroidAsync
dependencies {
compile 'com.koushikdutta.async:androidasync:2.+'
}
2.autobahn
官网:http://autobahn.ws/android/,下到jar包放项目里面就好了
使用起来同样很简单。
private WebSocketConnection mConnect = new WebSocketConnection();
//这里不要忘了要切到自己服务器的IP去
String url = "ws://192.168.250.38:8181/";
public void init() {
try {
mConnect.connect(url, new WebSocketHandler() {
@Override
public void onOpen() {
Log.i(TAG, "onOpen: ");
}
@Override
public void onTextMessage(String payload) {
Log.i(TAG, "onTextMessage: "+payload);
}
@Override
public void onClose(int code, String reason) {
Log.i(TAG, "onClose: " + code + "|" + reason);
}
});
} catch (WebSocketException e) {
e.printStackTrace();
}
}
Android通讯-webSocket的更多相关文章
- Android通讯:短信
Android通讯之短信功能实现: 使用android.telephony.SmsManager对象,可以发送短信和彩信.// 构造回调函数,短信发送结束后,会发出对应的Intent请求Intent ...
- Android通讯:通话
Android通讯之通话功能的实现: 在Android中,android.telephony.TelephonyManager对象是开发者获取当前通话网络相关信息的窗口,通过TelephonyMana ...
- H5即时通讯Websocket
/** * Created by admin on 2017/8/19. */ // import Vue from 'vue' // import axios from './HTTP.js' // ...
- Java Netty和Android之WebSocket,Springboot和Vue项目网址
在Netty上使用Websocket和网页上写个简单的websocket https://www.cnblogs.com/amibandoufu/p/11442881.html Android上使用w ...
- android 通讯类资料整理
https://github.com/koush/AndroidAsync(websocket) https://github.com/loopj/android-async-http http:// ...
- Android笔记之adb命令应用实例1(手机端与PC端socket通讯下)
通过adb和Android通讯需要引用adb相关的组件到项目中,分别为:adb.exe,AdbWinApi.dll,AdbWinUsbApi.dll. 可以在XXX\sdk\platform-tool ...
- 一、cocos2d-x 3.0 final使用httpclient编译到android,须要用到的android.mk
今天写一个网络框架,在vs上面非常欢快的执行车,心想,尼玛!cocos2d-x 3.0这么方便,预计不久的将来我就能回家种地了,由于不用程序猿了,直接cocos2dstudio拖界面了= =!!. 写 ...
- WebSocket数据包协议详解
其实我一直想不明白HTML5包装个应用层办议作为Socket通过基础目的是为了什么,其实直接支持Socket tcp相对来说更加简单灵活.既然标准已经制定而浏览器也支持那对于我们开发者来说只能用的分. ...
- vue+websocket+express+mongodb实战项目(实时聊天)
继上一个项目用vuejs仿网易云音乐(实现听歌以及搜索功能)后,发现上一个项目单纯用vue的model管理十分混乱,然后我去看了看vuex,打算做一个项目练练手,又不想做一个重复的项目,这次我就放弃颜 ...
随机推荐
- Flutter 34: 图解自定义 View 之 Canvas (一)
小菜最近在学习自定义 View,刚了解了一下 Paint 画笔的神奇之处,现在学习一下 Canvas 画布的神秘之处.Flutter 提供了众多的绘制方法,小菜接触不深,尽量都尝试一下. Canvas ...
- Miniconda虚拟环境管理工具命令方法
创建制定Python版本的虚拟环境 conda create --name 虚拟环境名称 Python=3.7.3(版本号) 进入指定虚拟环境 conda activate 虚拟环境名称 退出虚拟环境 ...
- 移动端设备管理平台 atx server2实践
目录 1.需求背景 2.初步调研 2.1.云测试平台 2.2.开源工具 2.3.VNC 2.4.企业内部自研云测试平台 3.ATX Server安装 依赖环境 安装rethinkdb 安装atx se ...
- bootstrapTable post提交数据,后台无法接收的问题
解决方法:contentType:"application/x-www-form-urlencoded; charset=UTF-8",
- php的三个常用判断函数
<?phperror_reporting(E_ERROR);$a;$b = false;$c = '';$d = 0;$e = null;$f = array(); echo 'empty', ...
- github(工蜂)密码过期时sourcetree重新登录
- IDEA设置CodeGlance颜色
CodeGlance是IDEA的mini地图插件, 默认情况下, 其颜色和编辑框的颜色基本一致, 而安装CodeGlance就是为了方便滚动框的上下拖拉, 颜色一致的话会将这种CodeGlance比拖 ...
- SqlMetaData异常 dbType xx 对于此构造函数无效。
今天在dapper中想扩展使用表值类型参数——tableValue.但是dapper不支持此类参数,于是扩展了一下.其中出现了一个问题. Microsoft.SqlServer.Server.SqlM ...
- JavaScript中的类(Class)
基本上,ES6的class可以看作只是一个语法糖,它的绝大部分功能,ES5都可以做到的,新的class写法是让对象原型的写法更加清晰,更像面向对象编程的语法而已. ES5生成例对象传统方法是通过构造函 ...
- mongodb命令----批量更改文档字段名
因为mongodb基于javascript的特性,为了体验cursor的威力我们不妨利用js的for循环创建记录 先创建文档 db.createCollection("columnsampl ...