.NET网络编程——TCP通信

一、网络编程的基本概念 :

1. 网络

        就是将不同区域的电脑连接到一起,组成局域网、城域网或广域网。把分部在不同地理区域的计算机于专门的外部设备用通信线路 互联成一个规模大、功能强的网络系统,从而使众多的计算机可以方便地互相传递信息,共享硬件、软件、数据信息等资源。

2. 计算机网络 

        通过传输介质、通信设施和网络通信协议,将地理位置相同的具有独立功能的多台计算机及其外部设备连起来,实现资源共享 和数据传输的系统。

3. 通信协议

计算机网路中实现通信必须有一些通信协议的规定,对传输代码、代码结构、传输控制步骤出错控制等制定标准。

4. 通信接口

为了使两个节点之间能进行对话,必须在他们之间建立通信工具(即接口),使彼此之间能进行信息交换。

5. 网络分层

       1. 由于结点之间联系很复杂,在指定协议时,把复杂成份分解成一些简单的成份,再将他们复合起来。最常用的复合方式是层次 方式,即同层间可以通信、上一层可以调用下一层,而与再下一层不发生关系

        2. TCP/IP是一个协议族,也是按照层次划分,共四层:应用层,传输层,互连网络层,接口层(物理+数据链路层)

        3. OSI网络通信协议模型,是一个参考模型,而TCP/IP协议是事实上的标准。TCP/IP协议参考了OSI模型,但是并没有严格按照OSI规 定的七层标准去划分,而只划分了四层,这样会更简单点,当划分太多层时,你很难区分某个协议是属于哪个层次的

二、网络编程三要素 

1. IP地址

        要想让网络中的计算机能够互相通信,必须为计算机指定一个标识号,通过这个标识号来指定要接受数据的计算机和识别发送 的计算机,而IP地址就是这个标识号,也就是设备的标识。

1.1 IP地址分为两大类

  1. IPv4:是给每个连接在网络上的主机分配一个32bit地址。按照TCP/IP规定,IP地址用二进制来表示,每个IP地址的 长32bit,也就是4个字节。
  2. IPv6:由于互联网的蓬勃发展,IP地址的需求量愈来愈大,但是网络地址资源有限,使得IP的分配越发紧张。为了扩 大地址空间,通过IPv6重新定义地址空间,采用128bit地址长度,每16个字节一组,分成8组十六进制数,这就解决 了网络地址资源数量不够的问题。

1.2 InetAddress类 (在Java中使用InetAddress类代表IP)

        常用的方法 :

String getHostAddress ()返回IP地址字符串(以文本表现形式)
String getHostName ()返回此IP地址的主机名
Byte[] getAddress ()返回此InetAddress对象的原始IP地址

2. 端口

2.1 概念:

        网络的通信,本质上是两个应用程序的通信,每台计算机都有很多的应用程序。IP地址是唯一的标识网络的设备,端口 号就是唯一标识设备中的应用程序,也就是应用程序的标识。

2.2 端口号:

        用两个字节表示的整数,它的取值范围是0~65535。其中,0~1023之间的端口号用于一些知名的网络服务和应用,普通 的应用程序需要使用1024以上的端口号。如果端口号被另外一个服务或应用所占用,会导致当前程序启动失败。

2.3 IntetSocketAddress类

        包含IP和端口信息,常用于Socket通信。此类实现套接字数字地址(IP地址+端口号),不依赖任何协议。

        常用的方法 :

InetAddress getAddress()获得InetAddress
Int getPort ()获取端口号
String getHostName()获取主机名

三、协议

        通过计算机网络可以使多台计算机实现连接,位于同一网络中的计算机进行连接和通信时需要遵守一定的规则,这就好比在道 路中形势的汽车一定要遵守交通规则一样。在计算机网路中,这些连接和通信的规则被称为网络通信协议。它对数据的传输格式、传 输速率、传输步骤做了统一规定,通信双方必须同时遵守才能完成数据交换。

3.1 UDP协议

  1. 用户数据报协议(User Datagram Protocol)
  2. UDP是预无线通信协议,即在数据传输时,数据的发送端和接受端不建立逻辑连接。简单来说,当一台计算机向另外一台计算机 发送数据时,发送端不会确认接受端是否存在,就会发送出数据,同样接受端在收到数据时,夜不会向发送端反馈是否收到数 据
  3. 由于使用UDP协议消耗资源少,通信效率高,所以通常都会用于音频、视频和普通数据的传输
  4. 例如视频会议通常采用UDP协议,因为这种情况即使偶尔丢失一两个数据包,也不会对接受结果产生太大影响。但是在使用UDP 协议传送数据时,由于UDP的面向无连接性,不能保证数据的完整性,因此在传输重要数据时不建议使用UDP协议。

3.2 TCP协议

  • 传输控制协议(Transmission Control Protocol)
  • TCP协议是面向连接的通信协议,即传输数据之前,在发送端和接受端建立逻辑连接,然后再传输数据,它提供了两台计算机之 间可靠无差错的数据连接。在TCP连接中必须明确客户端于服务端,由于客户端向服务端发出连接请求,每次连接的创建都需要 经过“三次握手”;

3.3 三次握手

TCP协议中,在发送数据的准备阶段,客户端与服务器之间的三次交互,以保证连接的可靠性

第一次握手 : 客户端向服务器发送连接请求,等待服务器确认

第二次握手 : 服务器向客户端回送一个响应,通知客户端收到了连接请求

第三次握手 : 客户端再次向服务器发送确认信息,确认连接

        完成三次握手连接建立后,客户端和服务器就可以开始进行数据传输了。由于这种面向连接的特性,TCP协议可以保证传输数据 的安全,所以应用非常广泛。例如上传文件,下载文件、浏览网页。

3.3.1 TCP通信原理 :

        TCP通信协议是一种可靠的网络协议,它在通信的两端各建立一个Socket对象,从而在通信的两端形成网络虚拟链路,一旦建 立了虚拟的网络链路,两端的程序就可以通过虚拟链路进行通信。

  • 使用基于TCP协议的Socket网络编程实现,使用Socket对象来代表两端的通信端口
  • TCP协议基于请求-响应模式,第一次主动发起的程序被客户端(Client)程序
  • 第一次通讯中等待连接的程序被服务器(Serser)程序
  • 利用IO流实现数据的传输

四、TCP实现步骤(聊天案例)

1. 步骤

1、在服务端指定一个端口号来创建ServerSocket,并使用accept方法进行侦听,这将阻塞服务器线程,等待用户请求。

2、在客户端指定服务的主机IP和端口号来创建socket,并连接服务端ServerSocket,此时服务端accept方法被唤醒,同时返回一个 和客户端通信的socket。

3、在客户端和服务端分别使用socket来获取网络通信输入/输出流,并按照一定的通信协议对socket进行读/写操作。

4、通信完成后,在客户端和服务端中分别关闭socket。

2. 服务器端

  1. 创建ServerSocket(int port)对象        
  2. 在Socket上使用accept方法监听客户端的连接请求(阻塞等待连接功能)
  3. 接受并处理请求信息 • 将处理结果返回给客户端
  4. 关闭流和Socket对象

3. 客户端

  1. 创建Socket(Strng host , int port)对象
  2. 向服务器发送连接请求 • 向服务端发送服务请求 • 接受服务结果(服务响应)
  3. 关闭流和Socket对象

4. ServerSocket类

常用构造器 : ServerSocket(int port) 创建绑定到指定端口的服务器套接字

常用方法 :Socket accept() 侦听要连接到此套接字并接受它

Java为客户端提供了Socket类,为服务器端提供了ServerSocket类

构造方法:

Socket(InetAddress address , int port)address(IP地址), port(端口号)

创建流套接字并将其连接到指定IP地址的指定端口号;

常用方法 :

OutoutStream getOutputStream()返回套接字的输出流
InputStream getInputStream ()返回套接字的输入流
Void shutdownOutput()禁用套接字的输出流 

5. 利用实现客户端于服务器无线聊天功能

1. 服务器

package com.net;import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.Scanner;/*** 服务器* @author 云村小威** @2023年7月19日 下午10:02:11*/
public class Server {public static void main(String[] args) throws Exception {System.out.println("⁎⁎⁎⁎⁎⁎服务端⁎⁎⁎⁎⁎⁎");/* 创建服务器连接对象 */ServerSocket ss = new ServerSocket(6666);System.out.println("服务器已开启,等待连接...");/* 调用accept方法,客服端没有启动连接不能执行下一步(阻塞功能) */Socket server = ss.accept();System.out.println("客户端连接成功");/* 获取输入流,读取客户端发送的数据 */InputStream inputStream = server.getInputStream();BufferedReader br = new BufferedReader(new InputStreamReader(inputStream));/* 获取输出流,向客户端回写数据 */Scanner zw = new Scanner(System.in);OutputStream outputStream = server.getOutputStream();BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(outputStream));while (true) {String readLine = br.readLine();System.out.println("客户端 :" + readLine);if ("拜拜".equals(readLine)) {System.out.println("再见");break;}System.out.println("请输入发送到客户端的内容:");String test = zw.next();/* 向客户端写入内容 */bw.write(test);bw.newLine();bw.flush();if ("拜拜".equals(test)) {System.out.println("再见");break;}}/* 关闭资源 */bw.close();outputStream.close();br.close();inputStream.close();server.close();ss.close();}
}

2. 客户端

package com.net;import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.InetAddress;
import java.net.Socket;
import java.util.Scanner;/*** 客户端* @author 云村小威** @2023年7月19日 下午10:02:00*/
public class Client {public static void main(String[] args) throws Exception {System.out.println("⁕⁕⁕⁕⁕客户端⁕⁕⁕⁕⁕");/* 创建Socket对象,请求连接 */Socket client = new Socket(InetAddress.getByName("127.0.0.1"), 6666);System.out.println("服务器连接成功...");/* 获取输出流对象,向服务器写入数据 */OutputStream outputStream = client.getOutputStream();BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(outputStream));/* 获取输入流对象,读取服务器数据 */InputStream inputStream = client.getInputStream();BufferedReader br = new BufferedReader(new InputStreamReader(inputStream));/* 向服务器发送信息 */Scanner zw = new Scanner(System.in);while (true) {System.out.println("请输入发送到服务器的内容:");String test = zw.next();/* 向服务器写入内容 */bw.write(test);bw.newLine();bw.flush();if ("拜拜".equals(test)) {System.out.println("再见");break;}/* 每次读取一个字节数组 */String content = br.readLine();System.out.println("服务器 : " + content);if ("拜拜".equals(content)) {System.out.println("再见");break;}}/* 关闭资源 */br.close();inputStream.close();bw.close();outputStream.close();client.close();}
}

3. 控制台版 效果

209fc2eac0a14234bd5ad4511ee33711.gif

    感谢您的观看,我会在本专栏持续更新,后续更新多线程等知识。接下来就可以利用多线程实现窗体实时无线聊天功能,请点击进入JAVA多线程 !

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/73383.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

eclipse版本与jdk版本对应关系

官网:Eclipse/Installation - Eclipsepedia eclipse历史版本(2007-):Older Versions Of Eclipse - Eclipsepedia Eclipse Packaging Project (EPP) Releases | Eclipse Packages

Spring Security 构建基于 JWT 的登录认证

一言以蔽之,JWT 可以携带非敏感信息,并具有不可篡改性。可以通过验证是否被篡改,以及读取信息内容,完成网络认证的三个问题:“你是谁”、“你有哪些权限”、“是不是冒充的”。 为了安全,使用它需要采用 …

亚马逊鲲鹏系统是怎么引流的?

亚马逊鲲鹏系统有三种引流方式,可设置通过亚马逊站点搜索、站外引流、直接访问产品页面进入到相关产品页面进行操作。 1、通过亚马逊站点搜索 正常的登录到我们的亚马逊主页,然后通过设置关键词及asin,最后进入你指定的产品,进行…

Redis的订阅者和发布者模式、主从双备和密码认证

四、Redis的订阅者和发布者模式、主从双备和密码认证 1、Redis的订阅者和发布者模式 两个数据库,一个是10,一个是15。订阅频道: 向频道推数据: 接收到数据: 2、redis的高可用(HA)主从双备 模拟…

基于传统检测算法hog+svm实现图像多分类

直接上效果图: 代码仓库和视频演示b站视频005期: 到此一游7758258的个人空间-到此一游7758258个人主页-哔哩哔哩视频 代码展示: 数据集在datasets文件夹下 运行01train.py即可训练 训练结束后会保存模型在本地 运行02pyqt.py会有一个可视化…

golang单元测试及mock总结

文章目录 一、前言1、单测的定位2、vscode中生成单测 二、构造测试case的注意事项1、项目初始化2、构造空interface{}3、构造结构体的time.Time类型4、构造json格式的test case 三、运行单测文件1、整体运行单测文件2、运行单个单测文件报错(1)command-l…

应用案例|基于3D视觉的高反光金属管件识别系统解决方案

Part.1 项目背景 在现代制造业中,高反光金属管件的生产以及质量的把控是一个重要的挑战。传统的2D视觉系统常常难以准确地检测和识别高反光金属管件,因为它们的表面特征不够明显,容易受到光照和阴影的干扰。为了应对这个问题,基于…

华为数通HCIP-IGMP(网络组管理协议)

IGMP(网络组管理协议) 作用:维护、管理最后一跳路由器以及组播接收者之间的关系; 应用:最后一跳路由器以及组播接收者之间; 原理:当组播接收者需要接收某个组别的流量时,会向最后…

kafka 理论知识

1 首先要了解kafka是什么 Kafka是一个分布式的消息订阅系统 1.1 kafka存储消息的过程 消息被持久化到一个topic中,topic是按照“主题名-分区”存储的,一个topic可以分为多个partition,在parition(分区)内的每条消息都有一个有序的id号&am…

高并发与性能优化的神奇之旅

作为公司的架构师或者程序员,你是否曾经为公司的系统在面对高并发和性能瓶颈时感到手足无措或者焦头烂额呢?笔者在出道那会为此是吃尽了苦头的,不过也得感谢这段苦,让笔者从头到尾去探索,找寻解决之法。 目录 第一站…

LabVIEW实现三相异步电机磁通模型

LabVIEW实现三相异步电机磁通模型 三相异步电动机由于经济和出色的机电坚固性而广泛用于工业化应用。这台机器的设计和驱动非常简单,但在控制扭矩和速度方面,它隐藏了相当大的功能复杂性。通过数学建模,可以理解机器动力学。 基于微分方程的…

uniApp 插件 Fvv-UniSerialPort 使用实例

接上一篇 uniApp 对接安卓平板刷卡器, 读取串口数据 , 本文将详细介绍如何使用插件读取到串口数据 原理 通过uniApp 插件读取设备串口数据, 解析后供业务使用; 步骤 创建uniApp 项目;添加插件 安卓串口通信 Fvv-UniSerialPort 安卓串口通信 Fvv-UniSerialPort - DCloud 插件…

二重积分1

目录 二重积分 二重积分的性质 ​编辑 中值定理 二重积分的计算 方法1:利用直角坐标计算 方法2:利用极坐标进行计算 适用于极坐标的二重积分的特征 对称性和奇偶性的应用 题目 例题1: 题目2: 题目3: 题目4&#x…

Vue3 Vite electron 开发桌面程序

Electron是一个跨平台的桌面应用程序开发框架,它允许开发人员使用Web技术(如HTML、CSS和JavaScript)构建桌面应用程序,这些应用程序可以在Windows、macOS和Linux等操作系统上运行。 Electron的核心是Chromium浏览器内核和Node.js…

Vol的学习

首先学习基础用法 1.查看系统基本信息 vol.py -f 路径 imageinfo 2.查看进程命令行 vol.py -f 路径 --profile系统版本 cmdline vol.py -f 路径 --profile版本 cmdscan 3.查看进程信息 vol.py -f 路径 --profile系统 pslist 通过树的方式返回 vol.py -f 路径 --profile系统…

HDFS架构刨析

HDFS架构刨析 概述HDFS架构图整体概述主角色:namenodefsimage内存元数据镜像文件edits log(Journal)编辑日志 从角色:datanode主角色辅助角色:secondarynamenode 重要特性主从架构分块存储机制副本机制namespace元数据…

新一代图像合成模型:Stable Diffusion XL(SDXL)上线!

几个使用Stable Diffusion XL 1.0生成的图像示例。 新的SDXL 1.0发布允许在本地计算机上运行的高分辨率人工智能图像合成。 周三,Stability AI发布了其下一代开源权重人工智能图像合成模型Stable Diffusion XL 1.0(SDXL)。它可以根据文本描述…

STM32CUBUMX配置RS485 modbus STM32(从机)亲测可用

———————————————————————————————————— ⏩ 大家好哇!我是小光,嵌入式爱好者,一个想要成为系统架构师的大三学生。 ⏩最近在开发一个STM32H723ZGT6的板子,使用STM32CUBEMX做了很多驱动&#x…

【VUE】解决图片视频加载缓慢/首屏加载白屏的问题

1 问题描述 在 Vue3 项目中,有时候会出现图片视频加载缓慢、首屏加载白屏的问题 2 原因分析 通常是由以下原因导致的: 图片或视频格式不当:如果图片或视频格式选择不当,比如选择了无损压缩格式,可能会导致文件大小过大…

青蛙过河 [递推法]

青蛙过河 [递推法] 题目描述输入输出样例输入样例输出样例 递推解答A C 代码 题目描述 有一条河,左边一个石墩( A A A区)上有编号为 1 , 2 , 3 , 4 , … , n 1,2,3,4&am…