udp回射客户端

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#include <stdio.h>
#include <stdlib.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <errno.h>
#include <string.h>
 
const int maxline=4096;
 
char *sock_ntop(const struct sockaddr *sa, socklen_t salen) {
    char portstr[8];
    static char str[128];
     
    switch(sa->sa_family) {
    case AF_INET: {
        struct sockaddr_in * sin = (struct sockaddr_in *)sa;
        if(inet_ntop(AF_INET, &sin->sin_addr, str, sizeof(str)) == NULL) {
            return NULL;
        }
        if(ntohs(sin->sin_port) != 0) {
            snprintf(portstr, sizeof(portstr), ":%d", ntohs(sin->sin_port));
            strcat(str, portstr);
        }
        return str;
    }
    }
}
 
void dg_cli(FILE *fp, int sockfd, const struct sockaddr * pservaddr, socklen_t servlen) {
    int n;
    char sendline[maxline], recvline[maxline+1];
    char errbuff[maxline];
    socklen_t len;
    struct sockaddr *preply_addr;
 
    if((preply_addr=malloc(servlen)) == NULL) {
        strerror_r(errno, errbuff, maxline);
        fprintf(stderr, "malloc error: %s\n", errbuff);
        exit(-1);
    }
 
    while(fgets(sendline, maxline, fp) != NULL) {
        if(sendto(sockfd, sendline, strlen(sendline), 0, pservaddr, servlen)<0) {
            strerror_r(errno, errbuff, maxline);
            fprintf(stderr, "sendto error: %s\n", errbuff);
            exit(-1);
        }
 
        len=servlen;
        if((n=recvfrom(sockfd, recvline, maxline, 0, preply_addr, &len))<0) {
            strerror_r(errno, errbuff, maxline);
            fprintf(stderr, "recvfrom error: %s\n", errbuff);
            exit(-1);
        }
        printf("reply from %s\n", sock_ntop(preply_addr, len));
 
        if(len != servlen || memcmp(pservaddr, preply_addr, len) != 0) {
            printf("reply from %s (ignored)\n", sock_ntop(preply_addr, len));
            continue;
        }
        recvline[n]=0;
        fputs(recvline, stdout);
    }
}
 
int main(int argc, char **argv) {
    int sockfd;
    struct sockaddr_in servaddr;
    char errbuff[maxline];
 
    if(argc != 2) {
        fprintf(stderr, "usage: udpcli <IPaddress>\n");
        exit(-1);
    }
 
    if((sockfd=socket(AF_INET, SOCK_DGRAM, 0))<0) {
        strerror_r(errno, errbuff, maxline);
        fprintf(stderr, "socket error: %s\n", errbuff);
        exit(-1);
    }
     
    memset(&servaddr, 0, sizeof(servaddr));
    servaddr.sin_family = AF_INET;
    servaddr.sin_port = htons(9999);
    inet_pton(AF_INET, argv[1], &servaddr.sin_addr);
 
    dg_cli(stdin, sockfd, (struct sockaddr *)&servaddr, sizeof(servaddr));
     
    return 0;
}  

  

posted @   东宫得臣  阅读(15)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示