一对一通信:

服务器端:

public class ServerDemo {
public static void main(String[] args) {
ServerSocket serverSocket = null;
Socket socket = null;
BufferedReader reader = null;
try {
//设置服务端的端口号
serverSocket = new ServerSocket(8081);
//等待客户端发送请求
socket = serverSocket.accept();
//接收客户端发来的请求
reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
boolean flag = true;
while (flag){
String read = reader.readLine();
if("结束".equals(read)){
flag = false;
}
System.out.println("服务器接收消息:"+read);
}
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
reader.close();
socket.close();
serverSocket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
} 客户端:
public class ClientDemo {
public static void main(String[] args) {
Socket socket = null;
//使用PrintWriter时,调用println、print的方法时,可以不再调用flush方法进行刷新
PrintWriter writer = null;
try {
//客户端socket指定服务器的地址和端口号
socket = new Socket("127.0.0.1", 8081);
//发送消息到服务器
writer = new PrintWriter(new BufferedWriter(new OutputStreamWriter(
socket.getOutputStream())));
for (int i = 0; i < 10; i++) {
writer.println("发送消息 " + i);
}
writer.println("结束");
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
System.out.println("close......");
writer.close();
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
} 多客户端通信
服务端1:
public class ServerDouble {
public static void main(String[] args) {
ServerSocket serverSocket = null;
Socket socket = null;
try {
//设置服务端的端口号
serverSocket = new ServerSocket(8081);
//等待客户端发送请求
System.out.println("正在等待连接……");
while (true){
socket = serverSocket.accept();
System.out.println("连接上了:"+socket.getPort());
new ServerDoubleDemo(socket);
}
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
socket.close();
serverSocket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
服务端2:
public class ServerDoubleDemo extends Thread {
Socket socket = null;
BufferedReader reader = null;
public ServerDoubleDemo(Socket socket) {
this.socket = socket;
try {
reader = new BufferedReader(new InputStreamReader( socket.getInputStream()));
start();
} catch (IOException e) {
e.printStackTrace();
}
} @Override
public void run() {
try {
boolean flag = true;
while (flag){
String str = reader.readLine();
if("结束".equals(str)){
flag = false;
}
System.out.println("接收消息:"+str);
}
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
reader.close();
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
} 客户端同上:
public class ClientDemo {
public static void main(String[] args) {
Socket socket = null;
//使用PrintWriter时,调用println、print的方法时,可以不再调用flush方法进行刷新
PrintWriter writer = null;
try {
//客户端socket指定服务器的地址和端口号
socket = new Socket("127.0.0.1", 8081);
//发送消息到服务器
writer = new PrintWriter(new BufferedWriter(new OutputStreamWriter(
socket.getOutputStream())));
for (int i = 0; i < 10; i++) {
writer.println("发送消息 " + i);
}
writer.println("结束");
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
System.out.println("close......");
writer.close();
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
												

Java实现Socket通信的更多相关文章

  1. Flex通信-与Java实现Socket通信实例

    Flex通信-与Java实现Socket通信实例  转自:http://blessht.iteye.com/blog/1136888 博客分类: Flex 环境准备 [服务器端] JDK1.6,“ja ...

  2. java的socket通信

    本文讲解如何用java实现网络通信,是一个非常简单的例子,我比较喜欢能够立马看到结果,所以先上代码再讲解具体细节. 服务端: import java.io.BufferedReader; import ...

  3. Java的Socket通信----通过 Socket 实现 TCP 编程之多线程demo(2)

    JAVA Socket简介 所谓socket 通常也称作”套接字“,用于描述IP地址和端口,是一个通信链的句柄.应用程序通常通过”套接字”向网络发出请求或者应答网络请求. import java.io ...

  4. Java:Socket通信

    Socket通常也称作"套接字".用于描写叙述IP地址和port,是一个通信链的句柄.应用程序通常通过"套接字"向网络发出请求或者应答网络请求. ServerS ...

  5. Java的Socket通信简单实例

    服务端 package testlxd; import java.io.BufferedReader; import java.io.IOException; import java.io.Input ...

  6. C++服务器与java进行socket通信案例

    分类: [java]2012-10-08 12:03 14539人阅读 评论(46) 收藏 举报 注:本代码版权所有!!!转载时请声明源地址:http://blog.csdn.net/nuptboyz ...

  7. java的Socket通信例子及关于java.net.SocketException: Socket is closed错误

    今天写socket数据相互通信的时候,碰到一个及其蛋疼的错误.单向传输数据的时候server与client是没有问题的,但是两个都有输入输出操作的时候就出现了这个问题 java.net.SocketE ...

  8. java NIO socket 通信实例

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/zhuyijian135757/article/details/37672151 java Nio 通 ...

  9. JAVA ANDROID SOCKET通信检测(SERVER)连接是否断开

    Pre 解决思路 代码后记: 客户端app上的部分代码 调用: 服务器上: 客户端判断服务器是否还活着代码: PRE 在利用socket写通讯程序的时候,想检测服务器是否还活着. 从网上找了很多资料, ...

随机推荐

  1. vue2.x和vue1.0

    1.首先挂载方式上 在vue2.0中,如果使用body或者html作为挂载点,则会报以下警告: Do not mount Vue to <html> or <body> - m ...

  2. 20169207《linux内核原理与分析》第二周作业

    第一部分:学习MOOC网Linux内核分析的课程. 首先对冯诺依曼体系结构和存储程序计算机工作模型进行了了解,查阅资料,对冯诺依曼体系的特点与课堂上的相结合,真实明白了模型的特点. 在汇编C语言程序时 ...

  3. 第84讲:Scala中List和ListBuffer设计实现思考

    今天来学习了scala中的list和ListBuffer scala list 内部很多操作是listbuffer做的,因为改变元素,listbuffer非常高效,tl是var类型的  ,但是他属于s ...

  4. codeforces 982 c

    给你一棵树 让你进行切割 问你最多能切多少刀   使得每个连通分量size都是偶数 思路:首先  要是有奇数个节点的话   那么不管你怎么切割  都会有一个连通分量的size是奇数 所以只有偶数的情况 ...

  5. SRM482

    250pt 题意:给定n把锁,第i轮每间隔i个打开一个木有打开的.问最后打开的事几 思路:直接vector模拟 code: #line 7 "LockersDivOne.cpp" ...

  6. 1.buntu 安装redis

    方式一 :apt安装 在 Ubuntu 系统安装 Redi 可以使用以下命令: $sudo apt-get update $sudo apt-get install redis-server 启动 R ...

  7. nginx实现unigui群集

    nginx实现unigui群集 在笔者写此文的时候,UNIGUI1.50.x的版本已经发布,其提供的HyperServer已经支持群集. 有网友还专门为此做了群集方面的测试: 从上图可以看出:群集总共 ...

  8. cxGrid实现取消过滤和排序后定位到首行(单选和多选)

    cxGrid实现取消过滤和排序后定位到首行(单选和多选) 原创 2013年10月06日 18:42:24 2107 DataContoller中的函数FocusedRecordIndex没有反应,Fo ...

  9. 在Windows7系统上能正常使用的程序,Windows10运行后部分状态不能及时变更

    这是最近在开发一个通信项目时遇到的问题,一开始以为是窗体样式的原因,把窗体换成系统窗体之后还是在Win10上不能正常使用,后面突然想到会不会是匹配原因,试了一下,结果真的就正常了. 问题:例如一个通信 ...

  10. ASP.NET MVC 做的网站项目

    感谢博客园团队日夜为广大需要获取知识人们所做的奉献 博客园团队您们辛苦了 ASP.NET MVC 实现有论坛功能的网站(有iis发布网站 这是之前写的... www.lazyfitness.cn 经过 ...