模拟捕获SIGPIPE信号 实现TCP服务器

2024-03-19 12:58

本文主要是介绍模拟捕获SIGPIPE信号 实现TCP服务器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

server端代码:

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <sys/wait.h>
#include <unistd.h>
#include <arpa/inet.h>

void handler (int sig)   //信号处理函数
{
    printf("sig = %d\n", sig);
}

int main (int argc, char *argv[])
{
    int pid, bytes;
    int sockfd, newfd;
    socklen_t len;
    struct sockaddr_in my_addr, their_addr;
    char buffer[128];
    
    if (argc != 3){
        printf("Please input %s <IP-address> <Port>\n",argv[0]);
    }
    
    signal(SIGPIPE, handler); // 安装SIGPIPE 信号
    
    if (-1 == (sockfd = socket(AF_INET, SOCK_STREAM, 0))){  //创建socket文件描述符
        perror("Create socket failed");
        exit(EXIT_FAILURE);
    }

    memset(&my_addr, 0, sizeof(struct sockaddr_in*));
    my_addr.sin_family = AF_INET;
    my_addr.sin_port = htons(atoi(argv[2]));
    if (0 == (inet_aton(argv[1], (struct in_addr*) &my_addr.sin_addr.s_addr))){
        perror("argv[1]");
        exit(errno);
    }
    
    if(-1 == (bind(sockfd, (struct sockaddr *)&my_addr, sizeof(struct sockaddr)))){   // 绑定IP信息
        perror("bind failesd");
        exit(EXIT_FAILURE);
    }
    
    if (-1 == listen(sockfd, 5)){   //监听网络
        perror("listen failed");
        exit(EXIT_FAILURE);
    }

    len = sizeof(struct sockaddr_in);
    while(1){
        printf("Wait for new connect\n");
        if(-1 == (newfd = (accept(sockfd, (struct sockaddr *) &their_addr, &len)))){
            perror("Accept failed");
            exit(EXIT_FAILURE);
        }
        else{
            printf("server: got connection from %s, port %d\n",inet_ntoa(their_addr.sin_addr), ntohs(their_addr.sin_port));
            while (1){
                memset(&buffer, 0, 128);
                printf("pls send message to send:");
                fgets(buffer, 128, stdin);
                if ( !strncasecmp(buffer, "quit", 4)){
                    printf("I will quit!\n");
                    break;
                }
                bytes = write(newfd, buffer, strlen(buffer));
                if (bytes < 0){
                    printf("Send failure, errno code id %d, errno message is '%s'\n", errno, strerror(errno));
                    close(newfd);
                    break;
                }
                else
                    printf("Message :%s\t send successful, %dbyte send !\n", buffer, len);
            }
        }
        
    }
    close(sockfd);
    return 0;
}


client端代码:

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <sys/wait.h>
#include <unistd.h>
#include <arpa/inet.h>

int main (int argc, char *argv[])
{
    int sockfd, len;
    struct sockaddr_in dest;
    char buf[128];             //用于存放接收数据
    if (argc != 3){            //输入数据参数小于3个
        printf("Error format, it must be:\n %s IP_Address Port\n",argv[0]);
        exit(errno);
    }
    
    if (-1 == (sockfd = (socket(AF_INET, SOCK_STREAM, 0)))){ // 创建socket
        perror("Socket failed");
        exit(errno);
    }
    printf("Client socket Created\n");
    dest.sin_family = AF_INET;
    dest.sin_port = htons(atoi(argv[2]));
    if(0 == inet_aton(argv[1], (struct in_addr*) &dest.sin_addr.s_addr)){
        perror(argv[1]);
        exit(errno);
    }
    if(-1 == (connect(sockfd, (struct sockaddr *) &dest, sizeof(dest)))){
        perror("Connect failed");
        exit(errno);
    }
    memset(&buf, '\0', 128);
    while(1){
        len = recv(sockfd, buf, 128, 0);
        printf("Recvive data: buf = %s\n",buf);
    }
    close(sockfd);
    return 0; }

这篇关于模拟捕获SIGPIPE信号 实现TCP服务器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/826063

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

usaco 1.2 Transformations(模拟)

我的做法就是一个一个情况枚举出来 注意计算公式: ( 变换后的矩阵记为C) 顺时针旋转90°:C[i] [j]=A[n-j-1] [i] (旋转180°和270° 可以多转几个九十度来推) 对称:C[i] [n-j-1]=A[i] [j] 代码有点长 。。。 /*ID: who jayLANG: C++TASK: transform*/#include<

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、