Java:Socket通信
Socket通常也称作"套接字"。用于描写叙述IP地址和port,是一个通信链的句柄。应用程序通常通过"套接字"向网络发出请求或者应答网络请求。
ServerSocket用于server端,Socket是建立网络连接时使用的。在连接成功时,应用程序两端都会产生一个Socket实例,操作这个实例,完毕所需的会话。
对于一个网络连接来说,套接字是平等的,并没有区别,不由于在server端或在client而产生不同级别。套接字之间的连接过程能够分为三个步骤:server监听,client请求,连接确认。
实例一:基于TCP/IP协议的Socket通信一对一:
package z_test_Socket_Demo; import java.io.IOException;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket; public class TestServerSocket { public static void main(String[] args) {
// TODO 自己主动生成的方法存根
ServerSocket serverSocket = null;
Socket socket = null;
OutputStream outputStream = null;
try {
serverSocket = new ServerSocket(8888); // 指定监听端口
System.out.println("==>> accepting");
socket = serverSocket.accept(); // 监听client的请求,方法堵塞,请求成功,返回socket对象
outputStream = socket.getOutputStream(); // 获得输出流
String string = "==>> Hello client,This is a message from server"; // 随便给client发点东西
byte[] buffer = string.getBytes();
outputStream.write(buffer);
outputStream.flush();
} catch (IOException e) {
// TODO 自己主动生成的 catch 块
e.printStackTrace();
} finally {
try {
serverSocket.close();
socket.close();
outputStream.close();
} catch (IOException e) {
// TODO 自己主动生成的 catch 块
e.printStackTrace();
}
}
}
}
package z_test_Socket_Demo; import java.io.IOException;
import java.io.InputStream;
import java.net.InetAddress;
import java.net.Socket;
import java.net.UnknownHostException; public class TestClientSocket { public static void main(String[] args) {
// TODO 自己主动生成的方法存根
Socket socket = null;
InputStream inputStream = null;
try {
// socket = new Socket(InetAddress.getLocalHost(), 8888);
// 请求连接服务器的8888端口,构造方法通常能够指定IP地址
socket = new Socket("10.25.26.141", 8888);
inputStream = socket.getInputStream(); // 获得输入流
byte[] buffer = new byte[64];
int temp = 0;
while ((temp = inputStream.read(buffer)) != -1) { // 将数据读入字节数组,此方法堵塞
System.out.println(new String(buffer));
}
} catch (UnknownHostException e) {
// TODO 自己主动生成的 catch 块
e.printStackTrace();
} catch (IOException e) {
// TODO 自己主动生成的 catch 块
e.printStackTrace();
} finally {
try {
socket.close();
inputStream.close();
} catch (IOException e) {
// TODO 自己主动生成的 catch 块
e.printStackTrace();
}
}
}
}
先执行服务器端,打印结果:
==>> accepting
然后执行client,打印结果:
==>> Hello client,This is a message from server
实例二:基于TCP/IP协议的Socket通信一对多:
仅仅须要把服务器段用一个线程死循环就可以
package z_test_Socket_Demo; import java.io.IOException;
import java.io.OutputStream;
import java.net.ServerSocket;
import java.net.Socket; public class TestServerSocket { public static void main(String[] args) {
// TODO 自己主动生成的方法存根
new Thread(new ServerThread()).start();
} private static class ServerThread implements Runnable { @Override
public void run() {
// TODO 自己主动生成的方法存根
int i = 1;
while (true) {
ServerSocket serverSocket = null;
Socket socket = null;
OutputStream outputStream = null;
try {
serverSocket = new ServerSocket(8888); // 指定监听端口
System.out.println("==>> accepting client" + i++);
socket = serverSocket.accept(); // 监听客户端的请求,方法堵塞,请求成功。返回socket对象
outputStream = socket.getOutputStream(); // 获得输出流
String string = "==>> Hello client" + i++
+ ",This is a message from server"; // 随便给客户端发点东西
byte[] buffer = string.getBytes();
outputStream.write(buffer);
outputStream.flush();
} catch (IOException e) {
// TODO 自己主动生成的 catch 块
e.printStackTrace();
} finally {
try {
serverSocket.close();
socket.close();
outputStream.close();
} catch (IOException e) {
// TODO 自己主动生成的 catch 块
e.printStackTrace();
}
}
}
}
}
}
执行服务器段,打印结果:
==>> accepting client1
执行client,client打印结果:
==>> Hello client1,This is a message from server
再次执行client,client打印结果:
==>> Hello client2,This is a message from server
相当于两个不同的client请求连接server
弄懂的了基于TCP/IP协议的Socket通信,基于其它协议的Socket通信应该能够非常快就能弄明确了。
Java:Socket通信的更多相关文章
- java socket通信-传输文件图片--传输图片
ClientTcpSend.java client发送类 package com.yjf.test; import java.io.DataOutputStream; import java.io ...
- java Socket通信使用BufferedReader和BufferedWriter的注意事项
注意事项:readLine()要求有换行标识,write()要输出换行标识,要调用flush()刷新缓冲区. 以下是取自java socket通信中的一小段代码. BufferedReader rea ...
- Java Socket通信读取相关信息代码
转自:http://developer.51cto.com/art/201003/190206.htm Java Socket通信读取有不少需要我们注意的知识点.当我们在使用的时候有很多的问题摆在我们 ...
- Java socket通信
首先抛开语言层面,简单介绍一下socket通信过程: 1.服务器端开启监听端口,阻塞进程 等待客户端连接 2.客户端连接,这时就产生了一个socket socket就相当于一个传递消息的通道,一般都 ...
- Java Socket通信以及可能出现的问题解决
Java中基于TCP协议实现网络通信的两个类:客户端的Socket和服务器端的ServerSocket. Socket通信模型如图所示: 不管Socket通信的功能有多复杂,任何socket通信过程的 ...
- Java Socket通信实现私聊、群聊
前言 闲言少叙,上代码! 代码编写 server服务端 /** * 服务端 */ public class Server { private static ServerSocket server = ...
- Java Socket 通信实例 - 转载
基于Tcp协议的简单Socket通信实例(JAVA) 好久没写博客了,前段时间忙于做项目,耽误了些时间,今天开始继续写起~ 今天来讲下关于Socket通信的简单应用,关于什么是Socket以及一些 ...
- Java Socket通信实例
一.简单的客户端与服务器一对一连接: Socket通信的步骤: 1.创建ServerSocket和Socket 2.打开连接到Scket的输入/输出流 3.按照协议对Socket进行读/写操作 4.关 ...
- 【Java】Java Socket 通信演示样例
用socket(套接字)实现client与服务端的通信. 这里举两个样例: 第一种是每次client发送一个数据,服务端就做一个应答. (也就是要轮流发) 另外一种是client能够连续的向服务端发数 ...
- java Socket通信,客户端与服务端相互发消息
1.通信过程 网络分为应用层,http.ssh.telnet就是属于这一类,建立在传输层的基础上.其实就是定义了各自的编码解码格式,分层如下: 2.Socket连接 上述通信都要先在传输层有建立连接的 ...
随机推荐
- Swift自适应布局(Adaptive Layout)教程
通用的Storyboard 通用的stroyboard文件是通向自适应布局光明大道的第一步.在一个storyboard文件中适配iPad和iPhone的布局在iOS8中已不再是梦想.我们不必再为不同尺 ...
- Unity学习-摄像机的使用(六)
快速对齐摄像机 [选择摄像机-GameObject-Align With View] Game模板中显示的界面,就是摄像机拍摄后的画面 本次学习案例 添加一个地形,一个点光源,三个Cube 了解摄 ...
- Java中的异常注意点
在java中 使用throw关键字抛出异常 使用throws关键字声明异常 public static void main(String[] args) throws Exception{ ...
- ionic2/3 禁止屏幕旋转,禁止横屏,竖屏
ionic2/ionic3禁止屏幕旋转,及解除禁止旋转 1.添加插件: cmd到项目目录---> cordova plugin add cordova-plugin-screen-orienta ...
- CSS——行业动态demo
1.padding的运用:子div继承父div的宽,子div的padding-left值是不会撑大的. 2.背景图片的运用:不平铺.定位 3.ul本身就是一个盒子,它的高度是li中的字体的默认高度撑起 ...
- android studio 控件提示大写
方法一: 在第一行找到File进入找到setting,找到code completion 右侧复选框 选择-->None—->ok 方法二:<item name="andr ...
- 易语言 打开exe可执行文件、打开网页
打开文件--------按钮被单击事件 直接复制以下代码即可 .版本 2 .子程序 _按钮58_被单击 运行 (“exe文件路径”, 假, ) 打开网站--------按钮被单击事件 直接复制以下代码 ...
- java实现搜索附近地点或人的功能
前言 当前大多数app都有查找附近的功能, 简单的有查找周围的运动场馆, 复杂的有滴滴, 摩拜查找周围的车辆. 本文主要阐述查找附近地点的一般实现. 方案比较 方案1 (性能还不错) 数据库直接存经纬 ...
- 如何将工程推到github上
首先,读一下这个 Git-Pro中文版 步骤: 在本地文件系统中 git init 在github中新建项目(光新建就行了) 然后,出现下面这张图,打开sourceTree,按照上面的操作进行就行了. ...
- django-Celery分布式队列简单使用
介绍: Celery 是一个简单.灵活且可靠的,处理大量消息的分布式系统,并且提供维护这样一个系统的必需工具. 它是一个专注于实时处理的任务队列,同时也支持任务调度. worker:是一个独立的进程, ...