概述

上一篇简单的认识了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的更多相关文章

  1. Android通讯:短信

    Android通讯之短信功能实现: 使用android.telephony.SmsManager对象,可以发送短信和彩信.// 构造回调函数,短信发送结束后,会发出对应的Intent请求Intent ...

  2. Android通讯:通话

    Android通讯之通话功能的实现: 在Android中,android.telephony.TelephonyManager对象是开发者获取当前通话网络相关信息的窗口,通过TelephonyMana ...

  3. H5即时通讯Websocket

    /** * Created by admin on 2017/8/19. */ // import Vue from 'vue' // import axios from './HTTP.js' // ...

  4. Java Netty和Android之WebSocket,Springboot和Vue项目网址

    在Netty上使用Websocket和网页上写个简单的websocket https://www.cnblogs.com/amibandoufu/p/11442881.html Android上使用w ...

  5. android 通讯类资料整理

    https://github.com/koush/AndroidAsync(websocket) https://github.com/loopj/android-async-http http:// ...

  6. Android笔记之adb命令应用实例1(手机端与PC端socket通讯下)

    通过adb和Android通讯需要引用adb相关的组件到项目中,分别为:adb.exe,AdbWinApi.dll,AdbWinUsbApi.dll. 可以在XXX\sdk\platform-tool ...

  7. 一、cocos2d-x 3.0 final使用httpclient编译到android,须要用到的android.mk

    今天写一个网络框架,在vs上面非常欢快的执行车,心想,尼玛!cocos2d-x 3.0这么方便,预计不久的将来我就能回家种地了,由于不用程序猿了,直接cocos2dstudio拖界面了= =!!. 写 ...

  8. WebSocket数据包协议详解

    其实我一直想不明白HTML5包装个应用层办议作为Socket通过基础目的是为了什么,其实直接支持Socket tcp相对来说更加简单灵活.既然标准已经制定而浏览器也支持那对于我们开发者来说只能用的分. ...

  9. vue+websocket+express+mongodb实战项目(实时聊天)

    继上一个项目用vuejs仿网易云音乐(实现听歌以及搜索功能)后,发现上一个项目单纯用vue的model管理十分混乱,然后我去看了看vuex,打算做一个项目练练手,又不想做一个重复的项目,这次我就放弃颜 ...

随机推荐

  1. SURF算法源代码OPENSURF分析

    SURF算法源代码分析 平台:win x64 + VS2015专业版 +opencv2.4.11 配置类似参考OPENSIFT,参考我的另一篇博客:https://www.cnblogs.com/Al ...

  2. Vue介绍:vue导读3

    一.全局组件 二.父组件传递信息给子组件 三.子组件传递信息给父组件 四.vue项目开发 一.全局组件 <body> <!-- 两个全局vue实例可以不用注册全局组件,就可以使用 - ...

  3. python基础:数据类型阶段总结

    name =“   alex”1.移除name变量对应的值两边的空格,并输出处理结果      res=name.strip(’  ‘)      print(res) 2.判断neme变量对应的值是 ...

  4. [Abp vNext微服务实践] - 启动流程

    前几篇分别介绍了abp vNext微服务框架和微服务CI/CD环境搭建,本篇开始介绍vNext微服务框架的开发环境搭建. 环境准备 官方介绍的系统架构图如下: 上图中身份服务和网关服务已经集成在系统中 ...

  5. pip安装tesserocr时报错

    在Xubuntu上的python2虚拟环境中, 使用pip安装tesserocr时报错error: command 'x86_64-linux-gnu-gcc' failed with exit st ...

  6. kotlin函数加强

    在之前已经接触过了kotlin的函数了,这里再次加强学习下它,下面开始吧! Kotlin函数编写规则: 对照函数来理解其写法: 演练巩固: ①.编写函数, 实现四则运算. 接着来实现其它三个运算: 然 ...

  7. WebRtc的一些基本概念

    GCC:Google Congestion Control,谷歌提出的拥塞控制算法 REMB:Receiver Estimated Maximum Bitrate,  接收端最大接收码率估测,接收端会 ...

  8. SpringMVC——问题汇总

    1.html页面ajax请求/login.后台报: Request method 'GET' not supported 原因: 后台请求使用了method = POST,但是url请求没有formd ...

  9. Jenkins构建从github上克隆时,报Host key verification failed.

    首先在本地通过CMD执行git clone xxxxx时,可以成功的通过免密(SSH_KEY)克隆下来代码,但是通过Jenkins克隆时,就报如下信息: Cloning into 'GitHub'.. ...

  10. appium+python 【Mac】UI自动化测试封装框架介绍 <三>---脚本的执行

    我自己编写的脚本框架中,所有的脚本执行均放在一个py文件中,此文件作为启动文件执行,包含了运行此文件将执行脚本.分配设备端口.自启appium服务等. 详细的介绍待后期补充.