程序员人生 网站导航

Centos 64下实现socket通信

栏目:服务器时间:2015-04-21 09:09:11
源码:
/* File Name: server.c */ #include<stdio.h> #include<stdlib.h> #include<string.h> #include<errno.h> #include<sys/types.h> #include<sys/socket.h> #include<netinet/in.h> //Ineternet address family #include<arpa/inet.h> #define DEFAULT_PORT 8000 #define MAXLINE 4096 int main(int argc, char** argv) { int socket_fd, connect_fd; struct sockaddr_in servaddr; char buff[4096]; int n; //初始化Socket if( (socket_fd = socket(AF_INET, SOCK_STREAM, 0)) == ⑴ ){ printf("create socket error: %s(errno: %d) ",strerror(errno),errno); exit(0); } //初始化 memset(&servaddr, 0, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_addr.s_addr = htonl(INADDR_ANY);//IP地址设置成INADDR_ANY,让系统自动获得本机的IP地址。 servaddr.sin_port = htons(DEFAULT_PORT);//设置的端口为DEFAULT_PORT //将本地地址绑定到所创建的套接字上 if( bind(socket_fd, (struct sockaddr*)&servaddr, sizeof(servaddr)) == ⑴){ printf("bind socket error: %s(errno: %d) ",strerror(errno),errno); exit(0); } //开始监听是不是有客户端连接 if( listen(socket_fd, 10) == ⑴){ printf("listen socket error: %s(errno: %d) ",strerror(errno),errno); exit(0); } printf("======waiting for client's request====== "); while(1){ struct sockaddr_in cilent_addr; //客户端socket地址结构 socklen_t length = sizeof(cilent_addr); //阻塞直到有客户端连接,不然多浪费CPU资源。 if( (connect_fd = accept(socket_fd, (struct sockaddr*)&cilent_addr, &length)) == ⑴){ //客户真个socket地址结构会填写到cilent_addr结构体中 printf("accept socket error: %s(errno: %d)",strerror(errno),errno); continue; } //接受客户端传过来的数据 n = recv(connect_fd, buff, MAXLINE, 0); if( n < 0 ) { printf("Server Receive Data Faild! "); break; } //向客户端发送回应数据 if(!fork()){ /*子进程*/ if(send(connect_fd, "Hello,you are connected! ", 26,0) == ⑴) perror("send error"); close(connect_fd); exit(0); } buff[n] = ''; printf("recv msg from client: %s ", buff); printf("has a cilent connect ip %s! ", inet_ntoa(cilent_addr.sin_addr)); //打印出客户端地址信息 close(connect_fd); } close(socket_fd); }

/* File Name: client.c */ #include<stdio.h> #include<stdlib.h> #include<string.h> #include<errno.h> #include<sys/types.h> #include<sys/socket.h> #include<netinet/in.h> #define MAXLINE 4096 int main(int argc, char** argv) { int sockfd, n,rec_len; char recvline[4096], sendline[4096]; char buf[MAXLINE]; struct sockaddr_in servaddr; if( argc != 2){ printf("usage: ./client <ipaddress> "); exit(0); } if( (sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0){ printf("create socket error: %s(errno: %d) ", strerror(errno),errno); exit(0); } memset(&servaddr, 0, sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_port = htons(8000); if( inet_pton(AF_INET, argv[1], &servaddr.sin_addr) <= 0){ printf("inet_pton error for %s ",argv[1]); exit(0); } if( connect(sockfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) < 0){ printf("connect error: %s(errno: %d) ",strerror(errno),errno); exit(0); } printf("send msg to server: "); fgets(sendline, 4096, stdin); if( send(sockfd, sendline, strlen(sendline), 0) < 0) { printf("send msg error: %s(errno: %d) ", strerror(errno), errno); exit(0); } if((rec_len = recv(sockfd, buf, MAXLINE,0)) == ⑴) { perror("recv error"); exit(1); } buf[rec_len] = ''; printf("Received : %s ",buf); close(sockfd); exit(1); }

遇到到问题:

64位Centos下使用inet_ntoa()端毛病:

Segmentation fault (core dumped)

32位正常打印,64位却是段毛病,错在haddrp这个参数上,报错内容是说inet_ntoa的返回值是int,因此%s没法输出。

解决方法:

1. 如果用inet_ntoa()的话需要#include <arpa/inet.h> ,就正常了。

2. 使用inet_ntop()


最后通过arm-linux-gcc交叉编译server端  移植到开发板  工作正常。
------分隔线----------------------------
------分隔线----------------------------

最新技术推荐