TCP协议与UDP协议

网络编程有三个要素,分别是IP地址、端口号和通信协议,那本文主要讲述的是TCP与UDP这两种通信协议,以及编程的实现。

首先,我们需要了解一下IP地址、端口号、通信协议的相关知识。

一、IP地址
网络中的计算机使用IP地址来进行唯一标识,IP地址有IPv4和IPv6两种类型。IPv4采用十进制或二进制表示形式,十进制是一种比较常用的表示形式,如192.168.1.131,IPv6采用十六进制表示形式,一般不常用。

如何查看IP地址相关信息:

在Windows系统下,打开cmd,输入命令ipconfig,按回车即可查看。在Linux或Mac系统下,打开终端,使用ifconfig命令,按回车即可查看。

二、端口号
端口号是计算机中的应用程序的一个整数数字标号,用来区分不同的应用程序。

0 ~ 1024 为被系统使用或保留的端口号,0 ~ 65535为有效的端口号,也就是说我们要对一些程序定义端口号的时候,要选择1024 ~ 65535范围内的整数数字。

比如,以前学过的MySQL的端口号是3306,SQLServer的端口号是1433,查了一下Oracle的端口号是1521。

一定要把这些数据库对应的端口号,藏在深深的脑海里,以后在连接数据库的时候,会使用到端口号。

三、通信协议
说的通俗一点,通信协议就是网络通信中的规则,分为TCP协议和UDP协议两种。

第一种:TCP协议
英文名:Transmission Control Protocol
中文名:传输控制协议
协议说明:TCP是一种面向连接的、可靠的、基于字节流的传输层通信协议。

举例:打电话,需要双方都接通,才能进行对话

特点:效率低,数据传输比较安全

第二种:UDP协议
英文名:User Datagram Protocol
中文名:数据报协议
协议说明:UDP是一种面向无连接的传输层通信协议。

举例:发短信,不需要双方建立连接,But,数据报的大小应限制在64k以内

特点:效率高,数据传输不安全,容易丢包

四、三要素关系图与网络模型图
1、网络编程三要素关系图

注:图中端口号、IP地址为演示,并非真实

2、OSI参考模型与TCP/IP参考模型

五、TCP编程
TCP是基于字节流的传输层通信协议,所以TCP编程是基于IO流编程。

对于客户端,我们需要使用Socket类来创建对象。对于服务器端,我们需要使用ServerSocket来创建对象,通过对象调用accept()方法来进行监听是否有客户端访问。

客户端与服务器端图解:

客户端与服务器端实现步骤:

前提:创建一个项目,在项目中创建两个模块(model),一个模块用来放客户端相关代码,一个模块用来放服务器端相关代码。

目录结构如下图

 

客户端:

1、创建Socket对象,并指定服务器端应用程序的端口号和服务器端主机的IP地址。

2、使用Socket的对象调用getOutputStream()方法来获取字节输出流对象。

3、调用字节输出流的write(byte[] buf)或者write(int b)向服务器发送指定数据。

4、记得关闭流。

服务器端:

1、创建ServerSocket对象,并指定该应用程序的端口号,端口号必须和客户端指定的端口号一样。

2、使用ServerSocket对象的accept()方法来监听客户端发送过来的请求,返回值为Socket对象。

3、调用Socket对象的getInputStream()方法获取字节输入流对象

4、调用字节输入流对象的read(byte[] buf)或read()方法获取数据。

5、记得关闭流。

实例:

客户端向服务器端发送信息,并显示在服务器端。

Client类(客户端)

package cn.tkrnet.client;

import java.io.IOException;
import java.io.OutputStream;
import java.net.Socket;

public class Client {
public static void main(String[] args) throws IOException {

//创建Socket对象,指定要发送到服务器端的IP地址,以及服务器端应用程序接收的端口号
//localhost代表本机IP地址
Socket client = new Socket(“localhost”,9000);

//获取输出流,用于向服务器端发送数据
OutputStream os = client.getOutputStream();

os.write(“Java is my friend !”.getBytes());
System.out.println(“信息已发送”);

//关闭流
os.close();
client.close();
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
Server类(服务器端)

package cn.tkrnet.server;

import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;

public class Server {
public static void main(String[] args) throws IOException {
System.out.println(“–服务器端已开启–“);

//创建ServerSocket对象,这里的端口号必须与客户端的端口号相同
ServerSocket server = new ServerSocket(9000);

//调用方法accept(),用来监听客户端发来的请求
Socket socket = server.accept();

//获取输入流对象
InputStream is = socket.getInputStream();

//读取输入流中的数据
int b = 0;
while ((b =is.read()) != -1){
System.out.print((char)b);
}
//关闭流
is.close();
socket.close();
server.close();
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
提示:在运行程序时,一定要先运行服务器端的程序代码,再运行客户端的程序代码。因为客户端要向服务器发送请求,前提是服务器端要处于开启状态。

Server类(服务器端)运行结果:

–服务器端已开启–

1
2
Client类(客户端)运行结果:

信息已发送
1
Client类(客户端)运行后,Server类(服务器端)收到信息,运行结果:

–服务器端已开启–
Java is my friend !
1
2
实例分析:

服务器端启动后,服务器端的accept()方法一直处于监听状态,直到客户端连接了服务器,服务器端再从流中读取客户端发来的数据。

恕我直言,这是一个超级无敌简单的单向通信实例。
————————————————
版权声明:本文为CSDN博主「酷酷的猿」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/m0_47890251/article/details/107121432

免责声明:
本工作室所有程序与文章均为游戏爱好者自发进行共同探讨研究为目的。
所有买家自愿赞助的费用全部用于服务器、网络租赁与维护、更新等费用,本工作室完全没有任何赢利性商业行为。
本工作室提到的所谓“购买”、“充值”、“续费”等实质为赞助方式,并非商业用语所指的行为模式。
如果对阁下(任何个人、单位、团体、机关、企事业单位等)产生冒犯或者侵害,请您立即告知我们,我们将改正模式。
海神科技 » TCP协议与UDP协议

独家打造,全球唯一,每个细节我们都用心处理!

24小时自动发卡 联系QQ在线客服