有了上面的基础那么传输文件的实现就变得简单了,在传输时通常我们需要打开文件,并每次读入1024个字节的数据包,通过SSL加密传输即可,此处的文件传输功能在原生套接字章节中也进行过详细讲解,此处我们还是使用原来的密钥对...,实现一个服务端等待客户端上传,当客户端连接到服务端后则开始传输文件,服务端接收文件的功能。...服务端代码部分,此处我们只需要实现一个DownloadFile函数,该函数接收一个SSL套接字,与保存文件路径即可,其他部分同上。...= -1) { printf("客户端地址: %s --> 端口: %d --> 套接字: %d \n", inet_ntoa(their_addr.sin_addr), ntohs(their_addr.sin_port...,传入socket套接字句柄,需要发送的文件路径void UploadFile(SSL* ptr, const char* FilePath){ int FileSize = GetFileSize(
有了上面的基础那么传输文件的实现就变得简单了,在传输时通常我们需要打开文件,并每次读入1024个字节的数据包,通过SSL加密传输即可,此处的文件传输功能在原生套接字章节中也进行过详细讲解,此处我们还是使用原来的密钥对...,实现一个服务端等待客户端上传,当客户端连接到服务端后则开始传输文件,服务端接收文件的功能。...服务端代码部分,此处我们只需要实现一个DownloadFile函数,该函数接收一个SSL套接字,与保存文件路径即可,其他部分同上。...= -1) { printf("客户端地址: %s --> 端口: %d --> 套接字: %d \n", inet_ntoa(their_addr.sin_addr), ntohs...,传入socket套接字句柄,需要发送的文件路径 void UploadFile(SSL* ptr, const char* FilePath) { int FileSize = GetFileSize
服务端代码 import socket # 创建tcp服务套接字 def main(): tcp_server_socket = socket.socket(socket.AF_INET,...tcp_server_socket_for_file_name = socket.socket(socket.AF_INET, socket.SOCK_STREAM) print("1.套接字创建完毕...tcp_server_socket.listen(128) tcp_server_socket_for_file_name.listen(128) print("3.被动模式转换完毕") # 接收到新的连接则创建服务套接字...创建客户端socket client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 创建第二个socket(负责发送文件名...display_dir() file_index = int(input("请输入需要传送的文件序号:")) # 打开文件并通过socket.send发送 client_socket_for_file_name.send
在内核分析网络分组时,底层协议的数据将传输到跟高的层。而发送数据的时候顺序是相反的。每一层都是通过加(首部+净荷)传向跟底层,直至最终发送。 这些操作决定了网络的的性能。 就如下图所示 ?...linux因此设计了一个结构体 如下代码 /** * struct sk_buff - socket buffer * @next: Next buffer in list * @prev...unsigned char *head, *data, *tail, *end; }; 套接字换从区在各个层交换数据
那么我们就可以使用这些加密算法对网络中的数据包进行加密处理,加密算法此处我们先采用AES算法,在网络通信中,只需要在发送数据之前对特定字符串进行加密处理,而在接收到数据后在使用相同的算法对数据进行恢复即可,读者如果有了套接字编程的基础...0; } 接着是客户端代码,如下所示,首先设置aes_key密钥对,此处需要保持服务端与客户端密钥的一致性,在发送数据之前先调用AES算法对字符串进行加密处理,接着在调用send函数将加密后的字节序传输到服务器端...WSACleanup(); } system("pause"); return 0; } 读者可自行编译上方代码,首先运行服务端然后再运行客户端,至此数据会被加密传输到对端
一般情况下,当RSA密钥长度为1024位时,可以加密长度为128字节,密钥长度为2048位时,可以加密长度为245字节;当密钥长度为3072位时,可以加密长度为371字节。...20.5.1 加解密算法封装 在之前的章节中我们都是使用命令行的方式手动生成密钥对文件,其实在OpenSSL中我们完全可以使用SDK提供的函数自动生成对应的加密密钥对文件,如下一段代码中,CreateRSAPEM...} // 建立Socket套接字 SOCKET client_socket; client_socket = socket(AF_INET, SOCK_STREAM, 0); struct...if (WSAStartup(MAKEWORD(2, 0), &WSAData)) { return 0; } // 建立Socket套接字 SOCKET server_socket...ServerAddr.sin_port = htons(9999); ServerAddr.sin_addr.s_addr = inet_addr("127.0.0.1"); // 绑定套接字
在 SSL/TLS 协议中,加密算法是其中最核心的组成部分之一,SSL可以使用各类加密算法进行密钥协商,一般来说会使用RSA等加密算法,使用TLS加密针对服务端来说则需要同时载入公钥与私钥文件,当传输被建立后客户端会自行下载公钥并与服务端完成握手...privkey.pem也就是私钥,接着利用私钥文件生成cacert.pem证书文件,该文件的有效期为1095天也就是三年,当然此处由于是测试可以使用自定义生成,如果在实际环境中还是需要购买正规签名来使用的...,而当需要接收数据时则使用SSL_read函数,通过使用这两个函数即可保证中间的传输流程是安全的,其他流程与标准套接字编程保持一致,如下是服务端完整代码实现。...= 2) { WSACleanup(); return 0; } // 创建套接字 if ((sockfd = socket(AF_INET, SOCK_STREAM,...= -1) { printf("客户端地址: %s --> 端口: %d --> 套接字: %d \n", inet_ntoa(their_addr.sin_addr), ntohs
在 SSL/TLS 协议中,加密算法是其中最核心的组成部分之一,SSL可以使用各类加密算法进行密钥协商,一般来说会使用RSA等加密算法,使用TLS加密针对服务端来说则需要同时载入公钥与私钥文件,当传输被建立后客户端会自行下载公钥并与服务端完成握手...也就是私钥,接着利用私钥文件生成cacert.pem证书文件,该文件的有效期为1095天也就是三年,当然此处由于是测试可以使用自定义生成,如果在实际环境中还是需要购买正规签名来使用的。...服务端实现代码与原生套接字通信保持高度一致,在连接方式上同样采用了标准API实现,唯一的不同在于当accept函数接收到用于请求时,我们需要通过SSL_new产生一个SSL对象,当需要发送数据时使用SSL_write...,而当需要接收数据时则使用SSL_read函数,通过使用这两个函数即可保证中间的传输流程是安全的,其他流程与标准套接字编程保持一致,如下是服务端完整代码实现。...= 2) { WSACleanup(); return 0; } // 创建套接字 if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) ==
首先是写出服务器的代码,代码的思路是这样的: ①首先为服务器创建套接字,因为这个是TCP协议,TCP是面向连接的,因此服务器是需要进入监听状态才能让客户端连接,所以使用socket接口创建出来的套接字是属于监听套接字...,会给父进程发送信号 ServerceIO(new_sock); //关闭套接字,也就是关闭fd //如果忘记关闭不需要的文件描述符,导致文件描述符泄漏...,因此不需要关闭监听套接字 //选择新线程分离,就不需要等待了 //新线程分离后,就拿着提供服务的套接字走,去进行通信, 通信完毕关闭这个套接字即可 pthread_t tid;...⑥进行网络通信,使用文件读写的方式,read/wirte的方法。关 ⑦闭监听套接字close(fd),本质:a、在系统层面,释放曾经申请的文件资源和连接资源等待。...⑧关闭用于通信的套接字close() && server/client,本质是在网络层面进行四次挥手! 三次握手: 在服务器建立连接的时候: 调用socket, 创建文件描述符。
Linux网络编程套接字 零、前言 一、网络基础知识 1、源IP地址和目的IP地址 2、源MAC地址和目的MAC地址 3、认识端口号 4、PORT VS PID 5、TCP和UDP协议 6、网络字节序...二、socket编程接口 1、sockaddr结构 2、socket 常见API 零、前言 本章就Linux网络编程进行概念及接口学习,下一篇则是简单的进行上手网络套接字编程 一、网络基础知识 1...,但是在套接字编程时需要填入的一些数据字段是需要我们主动进行网络字节序的转化 为使网络程序具有可移植性,使同样的C代码在大端和小端计算机上编译后都能正常运行,可以调用以下库函数做网络字节序和主机字节序的转换...,还支持本地的进程间通信(域间套接字) 因此套接字提供了sockaddr_in结构体和sockaddr_un结构体,其中sockaddr_in结构体是用于跨网络通信的,而sockaddr_un结构体是用于本地通信的...为了让套接字的网络通信和本地通信能够使用同一套函数接口,于是就出现了sockeaddr结构体,该结构体与sockaddr_in和sockaddr_un的结构都不相同,但这三个结构体头部的16个比特位都是一样的
fcntl.h> #include #include #include #include #include #include #include #define NETLINK_TEST 18 #define MAX_PAYLOAD...SOCK_RAW, NETLINK_TEST); if (sock_fd < 0) { eprint(errno, "socket", __LINE__); return errno; } //将本地套接字与源地址绑定...sockaddr *)&src_addr, sizeof(src_addr)) < 0) { eprint(errno, "bind", __LINE__); return errno; } //绑定了套接字之后...struct iovec iov;iov.iov_base = (void *)&r;iov.iov_len = sizeof(r);//一切就绪后,将目的套接字地址与当前要发送的消息msg绑定,即将目的套接字地址复制给
服务器端的步骤如下: 1. socket: 建立一个socket 2. bind: 将这个socket绑定在某个文件上(AF_UNIX)或某个端口上(AF_INET)...读取或发送数据到客户端 6. close: 通信完成后关闭socket 客户端的步骤如下: 1. socket: 建立一个socket 2. connect: 主动连接服务器端的某个文件...int socket(int domain, int type, int protocol) domain:指定socket所属的域,常用的是AF_UNIX或AF_INET AF_UNIX表示以文件方式创建
填写struct sockaddr结构的前16位:本地通信设置为AF_UNIX,网络通信设置为AF_INET(IPv4)或AF_INET6(IPv6) type:套接字协议的传输类型:对于UDP的数据报式传输则填入...SOCK_DGRAM,对于TCP的流式传输则填入SOCK_STREAM protocol:创建套接字的协议类别。...相比于UDP套接字来说,TCP套接字与之在一些地方是相同的,但是TCP的特点是面向链接的流式套接字,所以还是有很大的区别的 1、创建套接字 同样的tcp的服务端和客户端首先第一件事是创建套接字文件...这是一个输入输出型参数 返回值:获取连接成功返回接收到的套接字的文件描述符,获取连接失败返回-1,同时错误码会被设置 套接字文件之间的区别: socket函数创建的套接字文件:用于不断获取客户端发来的连接请求...,同文件的读写是一样是流式的,那么对于TCP来说,使用文件读写的方式进行读写套接字文件同样可以达到数据发送和接收的目的 读取套接字文件数据,即为接收对应套接字建立链接的远端发送来的消息;向套接字文件进行写入数据
套接字最早是UC Berkeley为BSD操作系统设计的。现在POSIX标准化了套接字。在Linux和Unix下的套接字是一致的。...套接字是通信端点的一种抽象。在Linux下socket是文件的一种。也就是说可以使用read和write函数去处理套接字。...在Linux下创建一个原始套接字的时候,需要拥有超级用户权限,用来防止恶意程序。 在Linux下,我们使用函数socket来创建一个套接字,这和Python所提供的方法并没有什么区别。...这在同一域和套接字类型的时候是有用的,可以指定选择某一个特定的协议。 socket函数返回一个套接字描述符,本质上是一个文件描述符。...一般而言,除了lseek不能用来操作套接字以外,其余的文件操作函数都是可以的。
类似于在像QQ一样的文件+聊天服务器中, 既要传输文件,同时要把消息传过去, 而文件太大, 直接阻塞 可以将文件切分为小部分, 协程传递 文章目录 字节(可以二进制读取文件)切分 实现...字节(可以二进制读取文件)切分 def cut(self, byte:bytes, seg=segment) -> list: return [byte[x:x+seg] for x in range
长连接通常就是: 连接→数据传输→保持连接(心跳)→数据传输→保持连接(心跳)→……→关闭连接; 心跳包就是在客户端和服务端间定时通知对方自己状态的一个自己定义的命令字,按照一定的时间间隔发送,类似于心跳...** 1.对套接字编程的理解,它的协议是如何的? socket通常称为“套接字”,用于描述IP地址和端口,是一个通信链的句柄。应用程序通过套接字向网络发出请求或应答网络请求。...(2)客户端请求:客户端的套接字必须首先描述它要连接的服务器的套接字,指出服务器端套接字的地址和端口号,然后就向服务器端套接字提出连接请求。...(3)连接确认:是指当服务器端套接字监听到或者说接收到客户端套接字的连接请求,它就响应客户端套接字的请求,建立一个新的线程,把服务器端套接字的描述发给客户端,一旦客户端确认了此描述,连接就建立好了。...HTTP的传输速度慢,数据包大,数据传输安全性差,如实现实时交互,服务器性能压力大。
选项影响套接字操作,如 封包路由,OOB数据传输,获取和设置套接字选项分别是 getsockopt setsockopt 用法如下: int getsockopt(SOCKET s,int level...optval,int* optlen); int setsockopt(SOCKET s,int level,int optname,char* optval,int* optlen); 每个协议层套接字的选项有不同的级别...: 应用层:SOL_SOCKET 传输层:IPPROTO_TCP IPPROTO_UDP 网络层:IPPROTO_IP 阻塞模式下,可以调用recvfrom在指定的端口接收网络封包 如果封包还不到,设置套接字选项即可设置等待时间
套接字:通信的端点 套接字 有两种类型的套接字:基于文件的和面向网络的。 IPC:进程间通信。...Python只支持AF_UNIX(基于文件)、AF_NETLINK(使用标准的BSD套接字接口进行用户级别和内核级别代码之间的IPC)、AF_TIPC(透明的进程间通信)、AF_INET(基于网络)家族...面向连接的套接字与无连接的套接字 面向连接的套接字 面向连接的套接字:在进行通信之前必须先建立一个连接。这种类型的通信也称为虚拟电路或流套接字。 实现这种连接类型的主要协议是传输控制协议(TCP)。...无连接的套接字 与虚拟电路形成鲜明对比的是数据报类型的套接字,它是一种无连接的套接字。实现这种连接类型的主要协议是用户数据报协议(UDP)。...为了创建UDP套接字,必须使用SOCK_DGRAM(即datagram)作为套接字类型。因为这些套接字也使用因特网协议来搜寻网络中的主机,所以这个系统也称作UDP/IP。
Unix套接字通信之Udp tcp和udp的区别 Tcp是可靠、稳定的,需要经过三次握手来建立连接,收发消息经过确认、Udp是不可靠的、不需要建立连接 Tcp需要建立连接确认,速度要比Udp不需要经过连接的慢一点...*/ $file= 'unix_udp_server'; //创建socket $socket = socket_create(AF_UNIX,SOCK_DGRAM,0); //bind 到文件...socket_bind($socket,$file); while (1) { //从套接字接收数据,无论它是否面向连接 $len = socket_recvfrom($socket...($status); fprintf(STDOUT,"child process exit pid=%s\n",$pid); 执行服务端代码php demo29.php,通过ls命令可以看到已经生成文件...,并且通过file命令可以看到生成的文件是一个socket文件,通过pstree -ap 查看启动的进程id,通过strace命令监控服务端进程 通过上面的执行结果可以看到,进程之间是可以进行通信的
套接字编程中,常见的有网络套接字编程,原始套接字编程,unix域间套接字编程。 网络套接字支持多主机跨网络通信,下面讲到的都是这个套接字编程。...原始套接字比较难,它可以绕过传输层直接访问网络层以及下面的层,抓包和网络监测工具就是通过原始套接字来完成的,文章不谈论原始套接字和unix域间套接字,只谈论网络套接字编程。...初始化服务器的第一步就是创建服务器的套接字,通过套接字文件描述符能够帮助我们实现UDP的全双工通信。...还有一个非常重要的知识点就是关于sockfd套接字文件描述符,对sockfd进行读写操作时,实际操作的是文件描述符指向的套接字文件控制块(socket file control block),该文件控制块内部有发送和接收的缓冲区...,在进行消息的读取和发送时离不开套接字文件控制块的帮助,我们称这样的网络通信为全双工通信。
领取专属 10元无门槛券
手把手带您无忧上云