TCP客户端大多都是异步操作,发送数据后只能在回调里处理,而有一些特殊业务可能需要发送后同步返回。 部分模块或支持库也有同步返回,但只支持单线程单包返回,经常看到有人在问这方面的问题 所以吃完粽子后趁消化之余闲着没事就顺手写了个  多线程TCP发送数据同步接收 实现思路: 1:发送数据前取一个唯一标识,和创建一个事件,保存该事件ID和唯一标识放到数组里 2:把唯一标识写入到数据里一并发送到服务器,然后调用事件等待 3:服务器接收到数据后处理完相关命令ID,在发回给客户端的数据里带上客户端发来的唯一标识 4:客户端收到数据时取出 唯一标识,再到数组里通过唯一标识取出 事件ID,再把数据放到数组里,触发事件ID,另外线程那边发送的就能收到通知了。 5:在发送线程收到事件触发后,根据唯一标识在数组里取出服务器返回的数据,再释放事件ID和删除相关缓存数据 这样就完成了发送数据后同步接收过程 TCP套件用的是  客户端/服务器组件 代码包含了 组包/拆包 该思路方法通用于所有TCP模块或支持库,如有需要请自行移植!
2024-12-02 23:50:16 11KB 网络相关源码
1
在本文中,我们将深入探讨基于Zynq的TCP客户端实现,特别是关注断线重连功能。Zynq是Xilinx公司的可编程系统芯片(PSoC),它集成了ARM Cortex-A9双核处理器和FPGA逻辑,使得硬件和软件的灵活结合成为可能。TCP(传输控制协议)是一种面向连接的、可靠的、基于字节流的传输层通信协议,广泛应用于互联网通信。本文将围绕如何在Zynq平台上构建一个能够处理网络中断并自动重连的TCP客户端SDK工程源码进行阐述。 我们要理解TCP客户端的基本工作原理。TCP客户端通过三次握手建立与服务器的连接,然后可以发送和接收数据。当网络出现问题导致连接中断时,TCP客户端需要检测到这个状态,并采取措施尝试重新连接。这通常涉及到心跳机制和超时重传策略。 在Zynq平台上实现TCP客户端,我们首先需要设置合适的TCP/IP堆栈。Xilinx提供了Vivado SDK(Software Development Kit),其中包含了用于网络应用开发的工具和库。开发者可以在C或C++中编写应用程序,利用SDK提供的网络库来处理TCP连接。 1. **心跳机制**:心跳包是维持TCP连接活跃的一种方法。客户端定时发送心跳包到服务器,如果服务器在指定时间内没有收到心跳包,就会认为连接已断开。同样,如果服务器未在预设时间内响应心跳包,客户端也会判断连接异常。心跳机制可以提前发现网络问题,避免数据丢失。 2. **超时重传策略**:当TCP数据段在网络中丢失或者延迟过大时,客户端需要有超时重传的机制。在Zynq SDK中,可以通过设置TCP重传超时(RTO)参数来实现。当超过这个时间未收到确认,客户端会重新发送数据。 3. **断线检测**:客户端需要监测TCP连接的状态,例如通过检测接收窗口的大小变化,或者监听TCP的FIN/ACK标志位。一旦检测到异常,立即启动重连过程。 4. **重连流程**:断线后,客户端首先需要关闭当前的TCP连接,清理相关资源。然后,按照正常的TCP连接流程重新发起连接请求,包括三次握手。在重试期间,可以设置重试次数和间隔时间,以防止过快的重试导致网络拥塞。 5. **错误处理和恢复**:在SDK工程源码中,应包含适当的错误处理代码,以便在重连失败时通知用户或采取其他恢复措施。这可能包括记录日志、显示错误消息,甚至尝试切换到备用服务器。 6. **源码结构**:在提供的"client"文件夹中,可能包含以下组件:主程序文件(如`main.c`或`main.cpp`)、TCP连接相关的函数库(如`tcp_connection.c/h`)、配置文件(如`config.h`)以及可能的测试脚本或Makefile。源码应清晰地组织和注释,以便理解和维护。 构建一个能够在Zynq平台上实现断线重连功能的TCP客户端SDK工程,需要对TCP协议、网络编程、Zynq硬件平台以及Vivado SDK有深入的理解。通过合理的心跳机制、超时策略和错误处理,可以确保客户端在面对网络不稳定时保持连接的可靠性。
2024-11-21 16:50:23 713KB 网络协议 zynq client
1
C#编写的TCP/IP通信 在计算机网络中,TCP/IP协议是最常用的协议之一,它提供了可靠的数据传输服务。C#语言可以使用TCP/IP协议来实现网络通信。在本文中,我们将介绍如何使用C#语言编写一个简单的TCP/IP通信程序。 第一部分: TCP/IP协议简介 TCP/IP协议是一种面向连接的协议,它可以保证数据的可靠传输。它由两个部分组成:TCP(Transmission Control Protocol)和IP(Internet Protocol)。TCP负责数据的传输和错误检查,而IP负责数据的路由选择。 第二部分: 客户端与服务器端的通信程序 在本文中,我们将实现一个简单的客户端与服务器端的通信程序。这个程序使用TCP/IP协议来实现数据的传输。 客户端连接服务器端代码: 在客户端,我们使用线程来发起连接请求。我们首先创建一个线程,然后启动该线程。在该线程中,我们使用TcpClient来连接服务器端。在连接成功后,我们可以使用BinaryReader和BinaryWriter来读取和写入数据。 ``` private void btnConnect_Click(object sender, EventArgs e) { // 通过一个线程发起请求,多线程 Thread connectThread = new Thread(ConnectToServer); connectThread.Start(); } private void ConnectToServer() { try { // 调用委托 statusStripInfo.Invoke(showStatusCallBack, "正在连接..."); if (tbxserverIp.Text == string.Empty || tbxPort.Text == string.Empty) { MessageBox.Show("请先输入服务器的 IP 地址和端口号"); } IPAddress ipaddress = IPAddress.Parse(tbxserverIp.Text); tcpClient = new TcpClient(); tcpClient.Connect(ipaddress, int.Parse(tbxPort.Text)); // 延时操作 Thread.Sleep(1000); if (tcpClient != null) { statusStripInfo.Invoke(showStatusCallBack, "连接成功"); networkStream = tcpClient.GetStream(); reader = new BinaryReader(networkStream); writer = new BinaryWriter(networkStream); } } catch { statusStripInfo.Invoke(showStatusCallBack,"连接失败"); Thread.Sleep(1000); statusStripInfo.Invoke(showStatusCallBack,"就绪"); } } ``` 客户端发送消息的代码: 在客户端,我们使用线程来发送消息。我们首先创建一个线程,然后启动该线程。在该线程中,我们使用BinaryWriter来写入数据。 ``` private void btnSend_Click(object sender, EventArgs e) { Thread sendThread = new Thread(SendMessage); sendThread.Start(tbxMessage.Text); } private void SendMessage(object state) { statusStripInfo.Invoke(showStatusCallBack, "正在发送..."); try { writer.Write(state.ToString()); Thread.Sleep(5000); writer.Flush(); statusStripInfo.Invoke(showStatusCallBac); } catch { statusStripInfo.Invoke(showStatusCallBack,"发送失败"); } } ``` 第三部分: 服务器端的实现 在服务器端,我们使用TcpListener来监听客户端的连接请求。我们首先创建一个TcpListener,然后使用AcceptTcpClient方法来接受客户端的连接请求。在连接成功后,我们可以使用BinaryReader和BinaryWriter来读取和写入数据。 本文介绍了如何使用C#语言编写一个简单的TCP/IP通信程序。这个程序使用TCP/IP协议来实现数据的传输,并且使用线程来实现多线程编程。
2024-11-07 11:46:45 152KB
1
QT框架是Qt公司开发的一种跨平台应用程序开发框架,它提供了丰富的API和工具,使得开发者能够构建功能强大的桌面、移动和嵌入式应用。在QT框架下实现基于TCP协议的多线程文件传输系统,可以充分利用多核处理器的性能,提高文件传输效率。以下是关于这个主题的详细知识点: 1. **QT框架基础**: - QT框架是用C++编写的,支持Windows、Linux、macOS、Android、iOS等多个操作系统。 - Qt库包含了图形用户界面(GUI)组件、网络编程、数据库访问、多媒体处理、XML解析等功能。 - 主要组件包括:QWidget(基本UI元素),QApplication(应用管理),QMainWindow(主窗口),QThread(线程管理)等。 2. **TCP协议**: - TCP(Transmission Control Protocol)是一种面向连接的、可靠的传输协议,它通过三次握手建立连接,保证数据的有序无损传输。 - TCP提供全双工通信,数据传输过程中有确认机制、流量控制和拥塞控制。 - 在QT框架中,可以使用QTcpServer和QTcpSocket类来实现TCP通信。 3. **QT中的网络编程**: - `QTcpServer`用于监听客户端连接请求,一旦有新的连接,会调用指定的槽函数处理。 - `QTcpSocket`代表一个TCP连接,负责数据的发送和接收。可以使用write()函数发送数据,read()或readLine()函数接收数据。 4. **多线程编程**: - 在QT中,`QThread`类允许创建并管理单独的执行线程。每个线程有自己的事件循环,可以独立处理任务。 - 使用多线程处理文件传输,可以避免单线程在大文件传输时阻塞UI,提高用户体验。 - 通常,服务器端在一个线程中处理多个客户端连接,而每个客户端连接可以在单独的线程中处理。 5. **文件传输实现**: - 文件传输通常涉及读取本地文件(如使用QFile类)和将文件内容写入网络流(QTcpSocket的write())。 - 为了确保数据完整,可以使用固定大小的缓冲区进行分块传输,并在每块数据后附加校验和。 - 客户端收到数据后,也需要使用相同的方法验证数据完整性,并写入本地文件。 6. **错误处理与连接管理**: - 在文件传输过程中,需要处理可能发生的网络中断、超时等问题。可以设置信号和槽来捕获这些异常并采取相应措施。 - 关闭连接时,确保所有的数据已发送并确认,然后调用QTcpSocket的disconnectFromHost()或close()方法。 7. **欢迎文档(welcome.txt)**: 这个文档可能包含项目简介、使用说明、版权信息等内容,为用户提供初步的指引。 8. **源代码(socket_qt.zip)**: 这个压缩包可能包含实现上述功能的QT项目源代码,包括服务器端和客户端的代码。用户可以通过研究这些代码来学习如何在QT中实现TCP文件传输。 QT框架下的TCP多线程文件传输系统结合了QT的强大功能和TCP的可靠性,提供了一种高效、稳定的数据交换方式。通过学习和实践这样的系统,开发者可以提升在网络编程和多线程应用开发方面的技能。
2024-11-03 23:57:25 41.67MB 网络协议 学习资料
1
在本项目中,我们关注的是一个使用C#编程语言开发的安捷伦程控电源66319BD-66321BD的演示程序。这个程序的主要目的是通过网络协议,如GPIB(通用接口总线)和TCP串口,实现对安捷伦电源的远程控制和通信。下面我们将深入探讨相关的知识点。 1. **C#编程语言**:C#是微软开发的一种面向对象的编程语言,广泛应用于Windows平台上的应用开发,包括桌面应用、游戏开发以及近年来的.NET框架中的Web服务和移动应用。在这个项目中,C#被用于编写与电源设备交互的软件,利用其强大的类库和易于理解的语法结构。 2. **安捷伦程控电源**:安捷伦科技(现 Keysight Technologies)是全球领先的测试测量公司,其电源产品广泛应用于实验室、研发和生产环境。66319BD-66321BD系列是高性能的直流电源,提供精确的电压和电流输出,可进行复杂的电源管理任务。程控电源可以通过编程接口进行控制,以实现自动化测试和测量。 3. **GPIB(通用接口总线)**:GPIB是一种标准的接口技术,常用于科学仪器间的通信,如在实验室环境中连接电源、示波器、信号发生器等。它允许设备间的数据传输,并实现对多个设备的同步控制。C#程序通过GPIB库可以发送命令到安捷伦电源,实现远程开关、设置电压/电流值等功能。 4. **TCP串口通信**:TCP(传输控制协议)是Internet协议的一部分,用于在网络设备之间建立可靠的数据传输。串口通信则是通过串行端口进行数据交换,常见于嵌入式系统和硬件设备。在这个项目中,TCP串口通信为C#应用程序提供了一种与电源设备进行数据交互的途径。 5. **软件/插件开发**:这里的"软件/插件"可能指的是开发的C#程序作为一个独立的应用或作为现有软件的扩展(插件)。开发者可能设计了一个用户友好的界面,允许用户输入参数并发送控制命令到电源设备。 6. **网络协议**:网络协议定义了设备间通信的规则。在这个项目中,GPIB和TCP都属于网络协议,它们确保了C#程序和安捷伦电源之间的通信有效、可靠。 7. **NI(National Instruments)**:这可能是文件列表中提到的一个关键词,可能意味着该项目使用了National Instruments的相关产品,如LabVIEW、NI GPIB驱动程序等。National Instruments是一家提供虚拟仪器软件和硬件解决方案的公司,常用于测试测量和控制系统。 这个项目展示了如何使用C#编程语言,结合GPIB和TCP串口通信协议,来控制安捷伦的程控电源,实现远程操作和自动化测试。开发者可能还利用了National Instruments的工具,以增强其软件的功能和兼容性。这样的工作对于科研、教育和工业生产环境都非常有价值,因为它可以提高测试效率,减少人工干预,并确保测试结果的一致性和准确性。
2024-10-30 14:39:29 459KB 网络协议
1
【基于Qt的TCP网络调试助手】是一个实用工具,旨在帮助开发者进行网络通信的测试和调试。这个工具由两部分组成:服务端和客户端,它们各自独立编写,以便于模拟真实的网络交互环境。服务端利用了多线程技术,确保了在处理多个客户端连接时的高效性和稳定性。 Qt是一个跨平台的C++图形用户界面应用程序开发框架,广泛应用于桌面、移动以及嵌入式系统。在本项目中,Qt不仅提供了构建用户界面的能力,还包含了对网络编程的支持,使得开发者可以方便地创建TCP服务器和客户端。Qt的网络模块提供了丰富的API,用于处理TCP套接字的创建、连接、数据传输和断开等操作。 多线程是服务端设计的关键特性。在TCP服务器中,通常每个客户端的连接都会占用一个独立的线程,以避免单线程模型中由于处理某一连接而阻塞其他连接的问题。使用多线程,服务端可以同时处理多个客户端的请求,提高了系统的并发能力。在Qt中,`QThread`类是实现多线程的核心,它提供了一种安全的方式来管理线程,避免了资源竞争和数据同步的问题。 TCP(Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层通信协议。在TCP中,数据被分割成报文段,并且每个报文段都有序号和确认号,确保了数据在传输过程中的正确性。在Qt中,开发者可以使用`QTcpServer`和`QTcpSocket`类来建立和管理TCP连接。`QTcpServer`用于监听和接受新的连接,而`QTcpSocket`则负责实际的数据收发。 在客户端方面,它也需要创建`QTcpSocket`实例来连接到服务端,并通过这个socket进行数据的发送和接收。客户端可能需要处理各种网络事件,如连接建立、数据到达或连接断开,这些都可以通过Qt的信号和槽机制来实现。 在实际使用中,调试助手会显示通信过程中的关键信息,如发送和接收的数据、连接状态等,这对于排查网络问题非常有帮助。开发者可以通过此工具测试不同场景下的网络通信,例如模拟大量并发连接、检查数据传输的完整性和正确性,或者验证错误处理机制。 "基于Qt的TCP网络调试助手"是一个利用Qt的网络功能和多线程技术实现的实用工具,对于理解和测试TCP网络通信具有很高的价值。通过这个工具,开发者可以更便捷地调试和优化他们的网络应用程序,提高代码的稳定性和性能。
2024-10-26 18:53:42 56KB 网络调试助手
1
【Lazarus下的TCP/UDP示例代码】是面向开发者的一款实用示例,适用于那些希望在不同操作系统上构建网络通信程序的人。Lazarus是一个开放源码的跨平台Delphi克隆,它提供了与Delphi几乎相同的集成开发环境(IDE)和组件库,即Free Pascal Compiler的支持。本示例主要涉及的是TCP(传输控制协议)和UDP(用户数据报协议),这两种协议是Internet协议栈中的关键部分,用于设备间的网络通信。 TCP是一种面向连接的、可靠的传输协议,它确保数据包按照发送顺序到达目的地,并且提供错误检测和丢失数据的重传机制。在TCP中,数据被分割成多个段并分配序列号,接收端会根据这些序列号重新组装数据,以确保数据的完整性。在TCP示例中,你可能会看到如何创建服务器来监听特定端口,等待客户端连接,以及如何建立安全的连接并进行数据交换。 UDP则是一种无连接的、不可靠的传输协议,它不保证数据包的顺序或完整性,也不提供错误检测和重传服务。UDP的优势在于其轻量级和低延迟,适合实时应用如视频流或在线游戏。在UDP示例中,你可能学习到如何创建一个广播服务器,向多个客户端发送数据,或者如何实现一个简单的客户端,向服务器发送请求并接收响应。 在压缩包中,`testnet.compiled`、`testnet.exe`是编译后的可执行文件,可以直接在支持的平台上运行。`main.lfm`是窗体文件,存储了应用程序的界面布局和组件设置。`testnet.lpi`和`testnet.lpr`分别是项目文件和工程文件,它们包含了项目的所有设置、引用库和源代码列表。`testnet.lps`可能是项目的源代码保存文件,而`main.lrs`、`main.o`和`testnet.o`则是编译过程中产生的中间文件,包含编译后的代码和资源。`fpc-res.or`是Free Pascal Compiler生成的资源文件。 通过这个示例,开发者可以学习到如何在Lazarus环境中创建TCP和UDP客户端及服务器,包括设置网络套接字、监听端口、接收和发送数据等基本操作。此外,还能了解到如何编写跨平台的代码,以便在Windows XP、Windows CE和Linux等不同操作系统上运行。对于那些想要深入理解网络编程或在Lazarus环境下开发网络应用的人来说,这是一个非常宝贵的资源。
2024-10-23 11:40:59 582KB lazarus TCP/UDP
1
【基于C#的TCP异步通信实现】 TCP(Transmission Control Protocol)是一种面向连接的、可靠的、基于字节流的传输层通信协议。在C#中,利用Socket类可以实现TCP通信,而为了提高系统的响应速度和处理能力,通常会采用异步编程方式。本文将深入探讨如何使用C#的Socket类实现TCP异步通信。 ### 一、TCP异步通信概述 TCP异步通信是通过使用非阻塞IO模型,使得程序在等待网络IO操作完成时,可以继续执行其他任务,提高了程序的并发性和效率。C#中的Socket类提供了多个异步方法,如BeginConnect、BeginAccept等,用于实现TCP异步通信。 ### 二、实验环境 - 开发工具:Visual Studio 2010 - 编程语言:C# - 协议:TCP ### 三、异步通信实现 #### 3.1 建立连接 1. **服务器端异步接受连接** 在服务器端,我们使用`BeginAccept`方法启动异步接受连接请求。创建一个本地终结点(IP地址和端口号),然后创建一个Socket实例并将其绑定到该终结点。接下来,调用`Listen`方法开始监听连接请求,最后调用`BeginAccept`方法,传入一个回调函数和状态对象。回调函数通常用于处理新连接,并通过`EndAccept`方法结束连接。 ```csharp IPAddress local = IPAddress.Parse("127.0.0.1"); IPEndPoint iep = new IPEndPoint(local, 13000); Socket server = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp); server.Bind(iep); server.Listen(20); server.BeginAccept(new AsyncCallback(Accept), server); void Accept(IAsyncResult iar) { Socket MyServer = (Socket)iar.AsyncState; Socket service = MyServer.EndAccept(iar); } ``` 2. **客户端异步连接** 客户端使用`BeginConnect`方法发起异步连接请求,传入目标IP地址和端口号,以及一个回调函数和状态对象。状态对象通常包含Socket实例,以便在回调函数中使用`EndConnect`方法。 ```csharp IPAddress ip = IPAddress.Parse("127.0.0.1"); IPEndPoint iep = new IPEndPoint(ip, 13000); Socket client = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp); client.BeginConnect(iep, new AsyncCallback(Connect), client); void Connect(IAsyncResult iar) { Socket clientSocket = (Socket)iar.AsyncState; try { clientSocket.EndConnect(iar); } catch (Exception e) { Console.WriteLine(e.ToString()); } finally { } } ``` #### 3.2 数据传输 在连接建立之后,可以使用`BeginSend`和`BeginReceive`方法进行异步的数据发送和接收。这两个方法同样需要回调函数来处理完成后的数据操作。发送数据时,使用`EndSend`方法结束发送,接收数据时使用`EndReceive`方法结束接收。 ### 四、TcpListener类的使用 除了直接使用Socket类进行异步连接,还可以使用`TcpListener`类。`TcpListener`提供了更简洁的方式来创建服务器,监听连接请求。创建`TcpListener`时指定本地终结点,然后调用`Start`方法开始监听。当有连接请求时,可以使用`AcceptSocket`或异步的`BeginAcceptSocket`方法来获取新的Socket实例。 ```csharp TcpListener listener = new TcpListener(iep); listener.Start(); Socket clientSocket = listener.AcceptSocket(); ``` 或者异步方式: ```csharp listener.BeginAcceptSocket(new AsyncCallback(AcceptClient), listener); void AcceptClient(IAsyncResult iar) { TcpListener listener = (TcpListener)iar.AsyncState; Socket clientSocket = listener.EndAcceptSocket(iar); } ``` 总结,C#的TCP异步通信主要依赖Socket类和TcpListener类提供的异步方法,通过这些方法,开发者可以在不阻塞主线程的情况下处理网络IO操作,从而实现高效的网络通信。在实际应用中,还需要考虑错误处理、数据编码解码、连接管理等复杂问题,以确保通信的稳定性和可靠性。
1
《TCP/IP Sockets in C 第二版》这本书主要围绕TCP/IP协议族及C语言在网络编程中的应用,尤其是socket编程进行详细介绍。书中使用大量代码示例,对理论知识与实际操作进行了有机结合,使得理解更为深刻。 我们从TCP/IP协议开始。TCP/IP是一套互联网协议族,它定义了数据在网络中传输的规则和标准,是互联网通信的基础。TCP/IP模型分为四层:链路层、网络层、传输层和应用层。其中,链路层主要处理与物理网络的接口问题;网络层主要负责数据包的路由选择;传输层主要为两台主机提供端到端的通信服务,主要的协议有TCP和UDP;应用层则负责处理特定的应用程序细节。 在了解了TCP/IP协议的基础上,我们可以讨论什么是socket。在计算机网络中,socket是一种抽象的网络编程接口,允许程序进行网络通信。使用socket编程模型,我们可以编写客户端(Client)和服务器端(Server)程序来实现网络中的数据交换。在C语言中,我们主要通过一系列的socket API函数来进行网络编程。 书中的一个重要部分是关于C语言的socket编程。C语言因其接近硬件的特性,一直是网络编程的首选语言,尤其是与UNIX系统的结合,使得C语言编写的socket程序具有良好的跨平台性。C语言在实现socket编程时,主要涉及到套接字的创建、绑定、监听、连接、数据传输以及关闭等一系列操作。这些操作都通过相应的系统调用实现,如socket()、bind()、listen()、accept()、connect()、send()、recv()和close()等。 书中还提到了一些重要的编程概念和策略。例如,需要理解阻塞与非阻塞调用、多线程以及网络字节序和主机字节序之间的转换。阻塞调用会使调用它的线程停下来等待操作完成,而非阻塞则不会。多线程是为了应对服务器处理多客户端的需求而产生的技术,可以并行处理多个任务,提高程序效率。网络字节序与主机字节序的问题是因为不同的计算机系统可能采用不同的字节序,而网络通信要求统一的字节序,因此需要在数据传输前进行转换。 此书第二版的出版背景是,在当时,网络课程包含编程实践并不常见。但是随着互联网的重要性日益增加,动手编程和真实世界协议示例的教育益处已被广泛认可。尽管现在有许多其他语言提供了对互联网的访问,但基于C语言的Berkeley sockets API的兴趣依然高涨。 关于这本书的版权信息,在这本书的版权页上我们看到了出版详情,包括出版社、版权声明、商标声明、ISBN号码以及出版地点等信息。版权页上还明确指出,没有出版社的明确书面许可,不能对这本书的任何部分进行复制、存储或以任何形式进行传输。 通过这本书的学习,读者将能深入理解TCP/IP协议的工作原理,掌握使用C语言进行网络编程的技能,并且能够编写出能够处理真实网络环境中的通信问题的程序。
2024-09-12 14:22:23 1.28MB TCP/IP Sockets
1
IP地址库SQL版(最新)
2024-09-06 11:46:09 80.57MB sql tcp/ip database 网络协议
1