客户端通过gethostbyname获取服务端IP地址

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
#include <stdio.h>
#include <stdlib.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <errno.h>
#include <string.h>
#include <netdb.h>
 
const int maxline=4096;
 
int main(int argc, char **argv) {
    int sockfd, n;
    char recvline[maxline+1], errbuff[maxline];;
    struct sockaddr_in servaddr;
    struct in_addr **pptr;
    struct in_addr *inetaddrp[2];
    struct in_addr inetaddr;
    struct hostent *hp;
    struct servent *sp;
 
    if(argc!=3) {
        fprintf(stderr, "usage: daytimetcpcli <hostname> <service>\n");
        exit(-1);
    }
 
    if((hp=gethostbyname(argv[1])) == NULL) {
        if(inet_aton(argv[1], &inetaddr)==0) {
            fprintf(stderr, "hostname error for %s: %s\n", argv[1], hstrerror(h_errno));
            exit(-1);
        } else {
            inetaddrp[0]=&inetaddr;
            inetaddrp[1]=NULL;
            pptr=inetaddrp;
        }
    } else {
        pptr=(struct in_addr **)hp->h_addr_list;
    }
 
    if((sp=getservbyname(argv[2], "tcp")) == NULL) {
        fprintf(stderr, "getservbyname error for %s\n", argv[2]);
        exit(-1);
    }
 
    for(; *pptr!=NULL; pptr++) {
        if((sockfd=socket(AF_INET, SOCK_STREAM, 0))<0) {
            strerror_r(errno, errbuff, maxline);
            fprintf(stderr, "socket error: %s\n", errbuff);
            continue;
        }
        memset(&servaddr, 0, sizeof(servaddr));
        servaddr.sin_family=AF_INET;
        servaddr.sin_port=sp->s_port;
        memcpy(&servaddr.sin_addr, *pptr, sizeof(struct in_addr));
        printf("trying %s: %d\n", inet_ntop(AF_INET, &servaddr.sin_addr, errbuff, sizeof(errbuff)), ntohs(servaddr.sin_port));
 
        if(connect(sockfd, (struct sockaddr *)&servaddr, sizeof(servaddr))==0) {
            break;
        } else {
            strerror_r(errno, errbuff, maxline);
            fprintf(stderr, "connect error: %s\n", errbuff);
            close(sockfd);
            exit(-1);
        }
    }
    if(*pptr==NULL) {
        fprintf(stderr, "unable to connect!\n");
        exit(-1);
    }
 
    while((n=read(sockfd, recvline, maxline))>0) {
        recvline[n]=0;
        if(fputs(recvline, stdout)==EOF) {
            fprintf(stderr, "fputs error\n");
            exit(-1);
        }
    }
    if(n<0) {
        fprintf(stderr, "read error.\n");
        exit(-1);
    }
    exit(0);
}

  

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