UDP和TCP的通信

UDP和TCP的通信UDP通信DatagramPacket前面介绍了UDP是一种面向无连接的协议,因此,在通信时发送端和接收端不用建立连接UDP通信的过程就像是货运公司在两个码头间发送货物一样。在码头发送和接收货物时都需要使用集装箱来装载货物,UDP通信也是一样,发送和接收的数据也需要使用“集装箱”进行打包,为

大家好,欢迎来到IT知识分享网。

 UDP通信

 

DatagramPacket

前面介绍了UDP是一种面向无连接的协议,因此,在通信时发送端和接收端不用建立连接

 

UDP通信的过程就像是货运公司在两个码头间发送货物一样。

 

在码头发送和接收货物时都需要使用集装箱来装载货物,UDP通信也是一样,发送和接收的数据也需要使用“集装箱”进行打包,为此JDK中提供了一个DatagramPacket类,该类的实例对象就相当于一个集装箱,用于封装UDP通信中发送或者接收的数据。

 

想要创建一个DatagramPacket对象,首先需要了解一下它的构造方法。在创建发送端和接收端的DatagramPacket对象时,使用的构造方法有所不同,

 

接收端的构造方法只需要接收一个字节数组来存放接收到的数据

而发送端的构造方法不但要接收存放了发送数据的字节数组,还需要指定发送端IP地址和端口号。

接收端:

UDP和TCP的通信

 

 

 

 

发送端:

 

UDP和TCP的通信

 

 

 

使用该构造方法在创建DatagramPacket对象时,不仅指定了封装数据的字节数组和数据的大小,还指定了数据包的目标IP地址(addr)和端口号(port)。

 

 

对象通常用于发送端,因为在发送数据时必须指定接收端的IP地址和端口号,就好像发送货物的集装箱上面必须标明接收人的地址一样。

 

UDP和TCP的通信

 

 

 DatagramSocket

DatagramPacket数据包的作用就如同是“集装箱”,可以将发送端或者接收端的数据封装起来。然而运输货物只有“集装箱”是不够的,还需要有码头

DatagramSocket类的作用就类似于码头,使用这个类的实例对象就可以发送和接收DatagramPacket数据包

UDP和TCP的通信

 

发送端:

UDP和TCP的通信

 

 接收端:

UDP和TCP的通信

 

 

1.1 UDP网络程序

发送端:

UDP和TCP的通信

 

 接收端:

UDP和TCP的通信

 

TCP通信

TCP通信是严格区分客户端与服务器端的,在通信时,必须先由客户端去连接服务器端才能实现通信,服务器端不可以主动连接客户端,并且服务器端程序需要事先启动,等待客户端的连接。

JDK中提供了两个类用于实现TCP程序,一个是ServerSocket类,用于表示服务器端,一个是Socket类,用于表示客户端

 

通信时,首先创建代表服务器端的ServerSocket对象,该对象相当于开启一个服务,并等待客户端的连接,然后创建代表客户端的Socket对象向服务器端发出连接请求,服务器端响应请求,两者建立连接开始通信。

 

ServerSocket

通过前面的学习知道,在开发TCP程序时,首先需要创建服务器端程序。JDKjava.net包中提供了一个ServerSocket类,该类的实例对象可以实现一个服务器段的程序。

UDP和TCP的通信

 

 UDP和TCP的通信

 

 

ServerSocket对象负责监听某台计算机的某个端口号,在创建ServerSocket对象后,需要继续调用该对象的accept()方法,接收来自客户端的请求。

 Socket

解了ServerSocket对象可以实现服务端程序,但只实现服务器端程序还不能完成通信,此时还需要一个客户端程序与之交互,为此JDK提供了一个Socket类,用于实现TCP客户端程序。

UDP和TCP的通信

 

 UDP和TCP的通信

 

 

 文件上传案例

 

客户端

UDP和TCP的通信

 

 服务器段

UDP和TCP的通信

 

 多线程上传

UDP和TCP的通信

 

 然后在建一个测试类

UDP和TCP的通信

 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/32825.html

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信