Java Socket通信实例
一、简单的客户端与服务器一对一连接:

Socket通信的步骤:
1、创建ServerSocket和Socket
2、打开连接到Scket的输入/输出流
3、按照协议对Socket进行读/写操作
4、关闭输入输出流、关闭Socket
废话不多说,直接上代码,服务端和客户端的注释写的很清楚!!!
package com.socket; import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.ServerSocket;
import java.net.Socket; public class Server {
public static void main(String[] args) {
try {
// 1.创建服务器端Socket对象,绑定并监听窗口
ServerSocket serverSocket = new ServerSocket(8888);
System.out.println("服务器已启动,等待客户端连接...");
// 2.调用accept()方法开始监听,等待客户端连接
Socket socket = serverSocket.accept();
// 3.获取输入流,并读取客户端信息
InputStream inputStream = socket.getInputStream();
InputStreamReader inputStreamReader = new InputStreamReader(inputStream);// 将字节流转换为字符流
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
String temp = null;
String info = "";
while ((temp = bufferedReader.readLine()) != null) {
info += temp;
System.out.println("已收到客户端连接");
System.out.println("服务端接收到客户端信息:" + info + "当前客户端ip:" + socket.getInetAddress().getHostAddress());
}
// 4.获取输出流,响应客户端的请求
OutputStream outputStream = socket.getOutputStream();
PrintWriter printWriter = new PrintWriter(outputStream);
printWriter.print("你好服务端已收到您的信息");
printWriter.flush();// 强行将缓冲区的数据输出
socket.shutdownOutput();// 关闭输出流
// 5.关闭对应的资源
printWriter.close();
outputStream.close();
bufferedReader.close();
inputStream.close();
inputStreamReader.close();
socket.close();
serverSocket.close(); } catch (IOException e) {
e.printStackTrace();
}
}
}
package com.socket; import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket; public class Client {
public static void main(String[] args) {
try {
// 1.创建客户端Socket,制定服务器地址和端口
Socket socket = new Socket("localhost", 8888);
// 2.获取输出流,向服务端发送信息
OutputStream outputStream = socket.getOutputStream();// 字节输出流
PrintWriter printWriter = new PrintWriter(outputStream);// 将输出流包装成打印流
printWriter.print("服务端你好,我是zz");// 内容
printWriter.flush();// 强制将缓冲区的数据输出
socket.shutdownOutput();// 关闭输出流
// 3.获取输入流,并读取服务器端的响应信息
InputStream inputStream = socket.getInputStream();// 获取一个输入流,接收服务端的信息
InputStreamReader inputStreamReader = new InputStreamReader(inputStream);// 包装成字符流,提高效率
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);// 缓冲区
String info = "";
String temp = null;// 临时变量
while ((temp = bufferedReader.readLine()) != null) {
info += temp;
System.out.println("客户端发送的消息为:" + info);
}
// 4.关闭相对应的资源
bufferedReader.close();
inputStream.close();
printWriter.close();
outputStream.close();
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
输出的结果为:
客户端发送的消息为:你好服务端已收到您的信息
服务器已启动,等待客户端连接...
已收到客户端连接
服务端接收到客户端信息:服务端你好,我是zz当前客户端ip:127.0.0.1
二、多个客户端与服务器连接:
package com.threadsocket; import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket; public class SocketThread extends Thread{
private Socket socket;
public SocketThread(Socket socket) {
this.socket = socket;
}
public void run() {
//根据输入输出流和客户端连接
try {
InputStream inputStream = socket.getInputStream();
//得到一个输入流,接收客户端传递的信息
InputStreamReader inputStreamReader = new InputStreamReader(inputStream);//提高效率将字节流转化为字符流
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);//加入缓冲区
String temp = null;
String info = "";
while((temp = bufferedReader.readLine())!=null) {
info+=temp;
System.out.println("已接收到客户端连接");
System.out.println("服务端接收到客户端信息:"+info+"当前客户端ip为:"+socket.getInetAddress().getHostAddress());
}
OutputStream outputStream = socket.getOutputStream();//获得一个输出流向服务端发送信息
PrintWriter printWriter = new PrintWriter(outputStream);//将输出流包装成打印流
printWriter.flush();
socket.shutdownOutput();//关闭输出流
//关闭相对应的资源
bufferedReader.close();
inputStream.close();
printWriter.close();
outputStream.close(); } catch (IOException e) {
e.printStackTrace();
}
}
}
package com.threadsocket; import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket; public class Server {
public static void main(String[] args) {
try {
ServerSocket serverSocket = new ServerSocket(8888);
System.out.println("服务端已启动,等待客户端连接...");
while(true) {
Socket socket = serverSocket.accept();//侦听并接收到此套接字的连接返回一个Socket对象
SocketThread socketThread = new SocketThread(socket);
socketThread.start();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
package com.threadsocket; import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket;
import java.net.UnknownHostException; public class Client {
public static void main(String[] args) {
try {
// 创建Socekt对象
Socket socket = new Socket("localhost", 8888);
// 根据输入输出流和服务端连接
OutputStream outputStream = socket.getOutputStream();// 获取一个输出流向服务端发送信息
PrintWriter printWriter = new PrintWriter(outputStream);
printWriter.print("服务端你好,我是客户1");
printWriter.flush();
socket.shutdownOutput();// 关闭输出流 InputStream inputStream = socket.getInputStream();// 获取一个输入流,接收服务端的信息
InputStreamReader inputStreamReader = new InputStreamReader(inputStream);// 包装成字符流,提高效率
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);// 缓冲区
String info = "";
String temp = null;// 临时变量
while ((temp = bufferedReader.readLine()) != null) {
info += temp;
System.out.println("客户端接收服务端发送信息:" + info);
}
// 关闭相对应的资源
bufferedReader.close();
inputStream.close();
printWriter.close();
outputStream.close();
socket.close();
} catch (UnknownHostException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
package com.threadsocket; import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.Socket;
import java.net.UnknownHostException; public class Client2 {
public static void main(String[] args) {
try {
// 创建Socekt对象
Socket socket = new Socket("localhost", 8888);
// 根据输入输出流和服务端连接
OutputStream outputStream = socket.getOutputStream();// 获取一个输出流向服务端发送信息
PrintWriter printWriter = new PrintWriter(outputStream);
printWriter.print("服务端你好,我是客户2");
printWriter.flush();
socket.shutdownOutput();// 关闭输出流 InputStream inputStream = socket.getInputStream();// 获取一个输入流,接收服务端的信息
InputStreamReader inputStreamReader = new InputStreamReader(inputStream);// 包装成字符流,提高效率
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);// 缓冲区
String info = "";
String temp = null;// 临时变量
while ((temp = bufferedReader.readLine()) != null) {
info += temp;
System.out.println("客户端接收服务端发送信息:" + info);
}
// 关闭相对应的资源
bufferedReader.close();
inputStream.close();
printWriter.close();
outputStream.close();
socket.close();
} catch (UnknownHostException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
运行结果:
服务端已启动,等待客户端连接...
已接收到客户端连接
服务端接收到客户端信息:服务端你好,我是客户2当前客户端ip为:127.0.0.1
已接收到客户端连接
服务端接收到客户端信息:服务端你好,我是客户1当前客户端ip为:127.0.0.1
Java Socket通信实例的更多相关文章
- Java Socket 通信实例 - 转载
基于Tcp协议的简单Socket通信实例(JAVA) 好久没写博客了,前段时间忙于做项目,耽误了些时间,今天开始继续写起~ 今天来讲下关于Socket通信的简单应用,关于什么是Socket以及一些 ...
- Flex通信-与Java实现Socket通信实例
Flex通信-与Java实现Socket通信实例 转自:http://blessht.iteye.com/blog/1136888 博客分类: Flex 环境准备 [服务器端] JDK1.6,“ja ...
- Linux下简单的socket通信实例
Linux下简单的socket通信实例 If you spend too much time thinking about a thing, you’ll never get it done. —Br ...
- 网络协议栈学习(一)socket通信实例
网络协议栈学习(一)socket通信实例 该实例摘自<linux网络编程>(宋敬彬,孙海滨等著). 例子分为服务器端和客户端,客户端连接服务器后从标准输入读取输入的字符串,发送给服务器:服 ...
- 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通信读取有不少需要我们注意的知识点.当我们在使用的时候有很多的问题摆在我们 ...
- (8)Linux(客户端)和Windows(服务端)下socket通信实例
Linux(客户端)和Windows(服务端)下socket通信实例: (1)首先是Windows做客户端,Linux做服务端的程序 Windows Client端 #include <st ...
- 基于Tcp协议的简单Socket通信实例(JAVA)
好久没写博客了,前段时间忙于做项目,耽误了些时间,今天开始继续写起~ 今天来讲下关于Socket通信的简单应用,关于什么是Socket以及一些网络编程的基础,这里就不提了,只记录最简单易懂实用的东西. ...
随机推荐
- [连载]Java程序设计(03)---任务驱动方式:寻找高富帅和屌丝
版权声明:本文为博主原创文章,请在转载时说明出处. https://blog.csdn.net/jackfrued/article/details/26163877 任务:相同在上一家公司.公司还须要 ...
- Spark的启动进程详解
Master和Worker是执行任务之前存在的进程 (类似于公司) Driver和Excutor是任务执行之后存在的进程(类似于公司接到项目后才成立的项目小组) 启动步骤: 启动Master资源管理进 ...
- JUC集合之 CopyOnWriteArraySet
CopyOnWriteArraySet介绍 它是线程安全的无序的集合,可以将它理解成线程安全的HashSet.有意思的是,CopyOnWriteArraySet和HashSet虽然都继承于共同的父类A ...
- 一个经典的PHP加密解密算法
项目中有时我们需要使用PHP将特定的信息进行加密,也就是通过加密算法生成一个加密字符串,这个加密后的字符串可以通过解密算法进行解密,便于程序对解密后的信息进行处理.最常见的应用在用户登录以及一些API ...
- POJ2228 Naptime
题目:http://poj.org/problem?id=2228 环形dp.开一维记录当前最后一份时间是否在睡.很精妙地分两类. 1.正常从1到n线性dp. 2.上边只有一种情况未覆盖:第一份时间就 ...
- Net分布式系统整体框架
Net分布式系统之一:系统整体框架介绍 一.设计目的 从事.Net平台开发系统已有8年多了,一直思考搭建.Net分布式系统架构.基于window平台搭建的大型分布式系统不多,之前了解过myspace. ...
- SpringCloud初体验:五、Sidecar 将 PHP 这类非 Java 生态语言的服务接入 Spring Cloud
先起一个 Sidecar 服务,一个PHP服务一个应用,和PHP服务部署在同一台机子,通过 localhost 访问,这样就解决了网络开销,相当于本地进程间调用 Sidecar 服务比较简单, 1.这 ...
- bzoj2242 计算器
Description 你被要求设计一个计算器完成以下三项任务: 1.给定y,z,p,计算Y^Z Mod P 的值: 2.给定y,z,p,计算满足xy≡ Z ( mod P )的最小非负整数: 3.给 ...
- python学习笔记--装饰器
1.首先是一个很无聊的函数,实现了两个数的加法运算: def f(x,y): print x+y f(2,3) 输出结果也ok 5 2.可是这时候我们感觉输出结果太单一了点,想让代码的输出多一点看起来 ...
- python接口自动化20-requests获取响应时间(elapsed)与超时(timeout)
前言 requests发请求时,接口的响应时间,也是我们需要关注的一个点,如果响应时间太长,也是不合理的. 如果服务端没及时响应,也不能一直等着,可以设置一个timeout超时的时间 关于reques ...