基于Tcp协议的简单Socket通信实例(JAVA)

 

好久没写博客了,前段时间忙于做项目,耽误了些时间,今天开始继续写起~

今天来讲下关于Socket通信的简单应用,关于什么是Socket以及一些网络编程的基础,这里就不提了,只记录最简单易懂实用的东西。

1、首先先来看下基于TCP协议Socket服务端和客户端的通信模型:

Socket通信步骤:(简单分为4步)

1.建立服务端ServerSocket和客户端Socket

2.打开连接到Socket的输出输入流

3.按照协议进行读写操作

4.关闭相对应的资源

2、相关联的API:

1.首先先来看下ServerSocket

类 ServerSocket

此类实现服务器套接字。服务器套接字等待请求通过网络传入。它基于该请求执行某些操作,然后可能向请求者返回结果。

服务器套接字的实际工作由 SocketImpl 类的实例执行。应用程序可以更改创建套接字实现的套接字工厂来配置它自身,从而创建适合本地防火墙的套接字。

一些重要的方法:(具体大家查看官方api吧)

ServerSocket(int port, int backlog) 
利用指定的 backlog 创建服务器套接字并将其绑定到指定的本地端口号。

bind(SocketAddress endpoint, int backlog) 
将 ServerSocket 绑定到特定地址(IP 地址和端口号)。

accept() 
侦听并接受到此套接字的连接

getInetAddress() 
返回此服务器套接字的本地地址。

close() 
关闭此套接字。

2.再来看下Socket

类 Socket  

此类实现客户端套接字(也可以就叫“套接字”)。套接字是两台机器间通信的端点。

套接字的实际工作由 SocketImpl 类的实例执行。应用程序通过更改创建套接字实现的套接字工厂可以配置它自身,以创建适合本地防火墙的套接字。

一些重要的方法:(具体大家查看官方api吧)

Socket(InetAddress address, int port) 
创建一个流套接字并将其连接到指定 IP 地址的指定端口号。

getInetAddress() 
返回套接字连接的地址。

shutdownInput() 
此套接字的输入流置于“流的末尾”。

shutdownOutput() 
禁用此套接字的输出流。

close() 
关闭此套接字。

3、代码实现:(注释很全,这里就不详细多说了)

服务端Server.java

1.创建ServerSocket对象,绑定并监听端口

2.通过accept监听客户端的请求

3.建立连接后,通过输出输入流进行读写操作

4.关闭相关资源

 1 import java.io.BufferedReader;
2 import java.io.IOException;
3 import java.io.InputStream;
4 import java.io.InputStreamReader;
5 import java.io.OutputStream;
6 import java.io.PrintWriter;
7 import java.net.ServerSocket;
8 import java.net.Socket;
9
10
11 public class Server {
12
13 /**
14 * Socket服务端
15 */
16 public static void main(String[] args) {
17 try {
18 ServerSocket serverSocket=new ServerSocket(8888);
19 System.out.println("服务端已启动,等待客户端连接..");
20 Socket socket=serverSocket.accept();//侦听并接受到此套接字的连接,返回一个Socket对象
21
22
23 //根据输入输出流和客户端连接
24 InputStream inputStream=socket.getInputStream();//得到一个输入流,接收客户端传递的信息
25 InputStreamReader inputStreamReader=new InputStreamReader(inputStream);//提高效率,将自己字节流转为字符流
26 BufferedReader bufferedReader=new BufferedReader(inputStreamReader);//加入缓冲区
27 String temp=null;
28 String info="";
29 while((temp=bufferedReader.readLine())!=null){
30 info+=temp;
31 System.out.println("已接收到客户端连接");
32 System.out.println("服务端接收到客户端信息:"+info+",当前客户端ip为:"+socket.getInetAddress().getHostAddress());
33 }
34
35 OutputStream outputStream=socket.getOutputStream();//获取一个输出流,向服务端发送信息
36 PrintWriter printWriter=new PrintWriter(outputStream);//将输出流包装成打印流
37 printWriter.print("你好,服务端已接收到您的信息");
38 printWriter.flush();
39 socket.shutdownOutput();//关闭输出流
40
41
42
43 //关闭相对应的资源
44 printWriter.close();
45 outputStream.close();
46 bufferedReader.close();
47 inputStream.close();
48 socket.close();
49
50 } catch (IOException e) {
51 e.printStackTrace();
52 }
53 }
54
55 }

客户端Client.java

1.创建Socket对象,指定服务端的地址和端口号

2.建立连接后,通过输出输入流进行读写操作

3.通过输出输入流获取服务器返回信息

4.关闭相关资源

 1 import java.io.BufferedReader;
2 import java.io.IOException;
3 import java.io.InputStream;
4 import java.io.InputStreamReader;
5 import java.io.OutputStream;
6 import java.io.PrintWriter;
7 import java.net.Socket;
8 import java.net.UnknownHostException;
9
10
11 public class Client {
12
13 /**
14 * Socket客户端
15 */
16 public static void main(String[] args) {
17 try {
18 //创建Socket对象
19 Socket socket=new Socket("localhost",8888);
20
21 //根据输入输出流和服务端连接
22 OutputStream outputStream=socket.getOutputStream();//获取一个输出流,向服务端发送信息
23 PrintWriter printWriter=new PrintWriter(outputStream);//将输出流包装成打印流
24 printWriter.print("服务端你好,我是Balla_兔子");
25 printWriter.flush();
26 socket.shutdownOutput();//关闭输出流
27
28 InputStream inputStream=socket.getInputStream();//获取一个输入流,接收服务端的信息
29 InputStreamReader inputStreamReader=new InputStreamReader(inputStream);//包装成字符流,提高效率
30 BufferedReader bufferedReader=new BufferedReader(inputStreamReader);//缓冲区
31 String info="";
32 String temp=null;//临时变量
33 while((temp=bufferedReader.readLine())!=null){
34 info+=temp;
35 System.out.println("客户端接收服务端发送信息:"+info);
36 }
37
38 //关闭相对应的资源
39 bufferedReader.close();
40 inputStream.close();
41 printWriter.close();
42 outputStream.close();
43 socket.close();
44 } catch (UnknownHostException e) {
45 e.printStackTrace();
46 } catch (IOException e) {
47 e.printStackTrace();
48 }
49
50 }
51
52 }

4、效果截图:

服务端:

客户端:

以上代码实现了单客户端和服务端的连接,若要实现多客户端操作,需要涉及到多线程,只要你把每个接收到的Socket对象单独开一条线程操作,然后用一个死循环while(true)去监听端口就行,这边直接给代码了

线程操作类:SocketThread.java

 1 import java.io.BufferedReader;
2 import java.io.IOException;
3 import java.io.InputStream;
4 import java.io.InputStreamReader;
5 import java.io.OutputStream;
6 import java.io.PrintWriter;
7 import java.net.Socket;
8
9 /**
10 * Socket多线程处理类 用来处理服务端接收到的客户端请求(处理Socket对象)
11 */
12 public class SocketThread extends Thread {
13 private Socket socket;
14
15 public SocketThread(Socket socket) {
16 this.socket = socket;
17 }
18
19 public void run() {
20 // 根据输入输出流和客户端连接
21 try {
22 InputStream inputStream = socket.getInputStream();
23 // 得到一个输入流,接收客户端传递的信息
24 InputStreamReader inputStreamReader = new InputStreamReader(
25 inputStream);// 提高效率,将自己字节流转为字符流
26 BufferedReader bufferedReader = new BufferedReader(
27 inputStreamReader);// 加入缓冲区
28 String temp = null;
29 String info = "";
30 while ((temp = bufferedReader.readLine()) != null) {
31 info += temp;
32 System.out.println("已接收到客户端连接");
33 System.out.println("服务端接收到客户端信息:" + info + ",当前客户端ip为:"
34 + socket.getInetAddress().getHostAddress());
35 }
36
37 OutputStream outputStream = socket.getOutputStream();// 获取一个输出流,向服务端发送信息
38 PrintWriter printWriter = new PrintWriter(outputStream);// 将输出流包装成打印流
39 printWriter.print("你好,服务端已接收到您的信息");
40 printWriter.flush();
41 socket.shutdownOutput();// 关闭输出流
42
43 // 关闭相对应的资源
44 bufferedReader.close();
45 inputStream.close();
46 printWriter.close();
47 outputStream.close();
48 } catch (IOException e) {
49 e.printStackTrace();
50 }
51
52 }
53
54 }

服务端类:Server.java

 1 import java.io.IOException;
2 import java.net.ServerSocket;
3 import java.net.Socket;
4
5 public class Server {
6
7 /**
8 * Socket服务端
9 */
10 public static void main(String[] args) {
11 try {
12 ServerSocket serverSocket = new ServerSocket(8888);
13 System.out.println("服务端已启动,等待客户端连接..");
14
15 while (true) {
16 Socket socket = serverSocket.accept();// 侦听并接受到此套接字的连接,返回一个Socket对象
17 SocketThread socketThread = new SocketThread(socket);
18 socketThread.start();
19 }
20
21 } catch (IOException e) {
22 e.printStackTrace();
23 }
24 }
25
26 }

客户端类:Client.java

 1 import java.io.BufferedReader;
2 import java.io.IOException;
3 import java.io.InputStream;
4 import java.io.InputStreamReader;
5 import java.io.OutputStream;
6 import java.io.PrintWriter;
7 import java.net.Socket;
8 import java.net.UnknownHostException;
9
10
11 public class Client {
12
13 /**
14 * Socket客户端
15 */
16 public static void main(String[] args) {
17 try {
18 //创建Socket对象
19 Socket socket=new Socket("localhost",8888);
20
21 //根据输入输出流和服务端连接
22 OutputStream outputStream=socket.getOutputStream();//获取一个输出流,向服务端发送信息
23 PrintWriter printWriter=new PrintWriter(outputStream);//将输出流包装成打印流
24 printWriter.print("服务端你好,我是客户1");
25 printWriter.flush();
26 socket.shutdownOutput();//关闭输出流
27
28 InputStream inputStream=socket.getInputStream();//获取一个输入流,接收服务端的信息
29 InputStreamReader inputStreamReader=new InputStreamReader(inputStream);//包装成字符流,提高效率
30 BufferedReader bufferedReader=new BufferedReader(inputStreamReader);//缓冲区
31 String info="";
32 String temp=null;//临时变量
33 while((temp=bufferedReader.readLine())!=null){
34 info+=temp;
35 System.out.println("客户端接收服务端发送信息:"+info);
36 }
37
38 //关闭相对应的资源
39 bufferedReader.close();
40 inputStream.close();
41 printWriter.close();
42 outputStream.close();
43 socket.close();
44 } catch (UnknownHostException e) {
45 e.printStackTrace();
46 } catch (IOException e) {
47 e.printStackTrace();
48 }
49
50 }
51
52 }

看下效果实现图:

这里只是抛砖引玉,在实际开发中,基于Socket编程,一般传递的并非字符串,很多情况下是对象,我们可以使用ObjectOutputStream将输出流对象序列化。

例如:

1             OutputStream outputStream = socket.getOutputStream();
2 ObjectOutputStream objectOutputStream=new ObjectOutputStream(outputStream);
3 User user=new User("admin","123456");
4 objectOutputStream.writeObject(user);

Java Socket 通信实例 - 转载的更多相关文章

  1. Java Socket通信实例

    一.简单的客户端与服务器一对一连接: Socket通信的步骤: 1.创建ServerSocket和Socket 2.打开连接到Scket的输入/输出流 3.按照协议对Socket进行读/写操作 4.关 ...

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

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

  3. Linux下简单的socket通信实例

    Linux下简单的socket通信实例 If you spend too much time thinking about a thing, you’ll never get it done. —Br ...

  4. 网络协议栈学习(一)socket通信实例

    网络协议栈学习(一)socket通信实例 该实例摘自<linux网络编程>(宋敬彬,孙海滨等著). 例子分为服务器端和客户端,客户端连接服务器后从标准输入读取输入的字符串,发送给服务器:服 ...

  5. java socket通信-传输文件图片--传输图片

    ClientTcpSend.java   client发送类 package com.yjf.test; import java.io.DataOutputStream; import java.io ...

  6. java Socket通信使用BufferedReader和BufferedWriter的注意事项

    注意事项:readLine()要求有换行标识,write()要输出换行标识,要调用flush()刷新缓冲区. 以下是取自java socket通信中的一小段代码. BufferedReader rea ...

  7. Java Socket通信读取相关信息代码

    转自:http://developer.51cto.com/art/201003/190206.htm Java Socket通信读取有不少需要我们注意的知识点.当我们在使用的时候有很多的问题摆在我们 ...

  8. (8)Linux(客户端)和Windows(服务端)下socket通信实例

    Linux(客户端)和Windows(服务端)下socket通信实例: (1)首先是Windows做客户端,Linux做服务端的程序 Windows   Client端 #include <st ...

  9. 基于Tcp协议的简单Socket通信实例(JAVA)

    好久没写博客了,前段时间忙于做项目,耽误了些时间,今天开始继续写起~ 今天来讲下关于Socket通信的简单应用,关于什么是Socket以及一些网络编程的基础,这里就不提了,只记录最简单易懂实用的东西. ...

随机推荐

  1. 大数据技术 - 分布式文件系统 HDFS 的设计

    本章内容介绍下 Hadoop 自带的分布式文件系统,HDFS 即 Hadoop Distributed Filesystem.HDFS 能够存储超大文件,可以部署在廉价的服务器上,适合一次写入多次读取 ...

  2. Web Component

    前言 Web Component不是新东西,几年前的技术,但是受限于浏览器兼容性,一直没有大规模应用在项目里,直到现在(2018年年末),除IE仍不支持之外,其它主流浏览器都支持Web Compone ...

  3. shell delete with line number

    If you want to delete lines 5 through 10 and 12: sed -e '5,10d;12d' file This will print the results ...

  4. 输出日文CSV乱码问题

    直接写用Excel打开时会乱码,需要加上下面代码中注释的三行 fos = new FileOutputStream(file, false); //fos.write( 0xef ); //fos.w ...

  5. VBA调用DOS程序两种方法

    Set wsh = VBA.CreateObject("WScript.Shell") 'wsh.Run strExePath & " g", vbHi ...

  6. 【转】Linux服务部署--Java(三) Nginx

    原文地址:Nginx Linux详细安装部署教程 一.Nginx简介 Nginx是一个web服务器也可以用来做负载均衡及反向代理使用,目前使用最多的就是负载均衡,具体简介我就不介绍了百度一下有很多,下 ...

  7. 理解Session缓存

    session的缓存有两大作用 (1)减少访问数据库的频率.应用程序从内存中读取持久化对象的速度显然比到数据库中查询数据的速度快多了,音系Session的缓存 可以提高数据库访问性能 (2)保证缓存中 ...

  8. 哈希表(散列表),Hash表漫谈

    1.序 该篇分别讲了散列表的引出.散列函数的设计.处理冲突的方法.并给出一段简单的示例代码. 2.散列表的引出 给定一个关键字集合U={0,1......m-1},总共有不大于m个元素.如果m不是很大 ...

  9. BZOJ5103 : [POI2018]Róznorodno

    从上到下枚举上下底边,那么涉及两行的添加和删除. 首先预处理出对于每一列,每个位置添加和删除时,是否会对往下$k$个里出现这个颜色造成影响. 然后对于每种颜色维护一个长度为$m$的bitset,表示哪 ...

  10. 狡猾的商人 [HNOI2005] [一题双解]

    Description 刁姹接到一个任务,为税务部门调查一位商人的账本,看看账本是不是伪造的.账本上记录了n个月以来的收入情况,其中第i 个月的收入额为Ai(i=1,2,3...n-1,n), .当 ...