网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket。下面就是Linux举例Unix也是一样的。下面例子连接一个IP,然后读取其数据。
代码实例中的服务器通过socket连接向客户端发送字符串"Hello, you are connected!"。只要在服务器上运行该服务器软件,在客户端运行客户软件,客户端就会收到该字符串。
该服务器软件代码如下:
服务器的工作流程是这样的:
首先调用socket函数创建一个Socket,然后调用bind函数将其与本机地址以及一个本地端口号绑定,然后调用listen在相应的socket上监听,当accpet接收到一个连接服务请求时,将生成一个新的socket。服务器显示该客户机的IP地址,并通过新的socket向客户端发送字符串"Hello,you are connected!"。最后关闭该socket。
代码实例中的fork()函数生成一个子进程来处理数据传输部分,fork()语句对于子进程返回的值为0。所以包含fork函数的if语句是子进程代码部分,它与if语句后面的父进程代码部分是并发执行的。
客户端程序代码如下:
这段代码基本上和第一个一样,些许不同!
#include#include #include #include #include #include #include #include #include #include #include #include #include #include #define SERVPORT 80 #define MAXDATASIZE 10240 /*每次最大数据传输量 */ int _test(){ int sock_fd; long recvbytes; char buf[MAXDATASIZE]; struct hostent *host; struct sockaddr_in serv_addr; if((host=gethostbyname("121.40.127.88")) == NULL) { herror("gethostbyname出错!"); exit(1); } if((sock_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { perror("socket创建出错!"); exit(1); } serv_addr.sin_family=AF_INET; serv_addr.sin_port=htons(SERVPORT); serv_addr.sin_addr = *((struct in_addr *)host->h_addr); bzero(&(serv_addr.sin_zero),8); printf("准备连接\n"); if(connect(sock_fd, (struct sockaddr *)&serv_addr, sizeof(struct sockaddr)) == -1) { perror("connect出错!"); exit(1); } printf("准备读取数据\n"); if((recvbytes=recv(sock_fd, buf, MAXDATASIZE, 0)) == -1) { perror("recv出错!"); exit(1); } buf[recvbytes] = ' '; printf("Received: %s",buf); close(sock_fd); return 0; }
代码实例中的服务器通过socket连接向客户端发送字符串"Hello, you are connected!"。只要在服务器上运行该服务器软件,在客户端运行客户软件,客户端就会收到该字符串。
该服务器软件代码如下:
#include#include #include #include #include #include #include #include #define SERVPORT 3333 /*服务器监听端口号 */ #define BACKLOG 10 /* 最大同时连接请求数 */ main() { int sock_fd,client_fd; /*sock_fd:监听socket;client_fd:数据传输socket */ int sin_size; struct sockaddr_in my_addr; /* 本机地址信息 */ struct sockaddr_in remote_addr; /* 客户端地址信息 */ if((sock_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { perror("socket创建出错!"); exit(1); } my_addr.sin_family=AF_INET; my_addr.sin_port=htons(SERVPORT); my_addr.sin_addr.s_addr = INADDR_ANY; bzero(&(my_addr.sin_zero),8); if(bind(sock_fd, (struct sockaddr *)&my_addr, sizeof(struct sockaddr)) == -1) { perror("bind出错!"); exit(1); } if(listen(sock_fd, BACKLOG) == -1) { perror("listen出错!"); exit(1); } while(1) { sin_size = sizeof(struct sockaddr_in); if((client_fd = accept(sock_fd, (struct sockaddr *)&remote_addr, &sin_size)) == -1) { perror("accept出错"); continue; } printf("received a connection from %s\n", inet_ntoa(remote_addr.sin_addr)); if(!fork()) { /* 子进程代码段 */ if(send(client_fd, "Hello, you are connected!\n", 26, 0) == -1) { perror("send出错!"); } close(client_fd); exit(0); } close(client_fd); } }
服务器的工作流程是这样的:
首先调用socket函数创建一个Socket,然后调用bind函数将其与本机地址以及一个本地端口号绑定,然后调用listen在相应的socket上监听,当accpet接收到一个连接服务请求时,将生成一个新的socket。服务器显示该客户机的IP地址,并通过新的socket向客户端发送字符串"Hello,you are connected!"。最后关闭该socket。
代码实例中的fork()函数生成一个子进程来处理数据传输部分,fork()语句对于子进程返回的值为0。所以包含fork函数的if语句是子进程代码部分,它与if语句后面的父进程代码部分是并发执行的。
客户端程序代码如下:
#include#include #include #include #include #include #include #include #define SERVPORT 3333 #define MAXDATASIZE 100 /*每次最大数据传输量 */ main(int argc, char *argv[]) { int sock_fd, recvbytes; char buf[MAXDATASIZE]; struct hostent *host; struct sockaddr_in serv_addr; if(argc< 2) { fprintf(stderr,"Please enter the server's hostname!\n"); exit(1); } if((host=gethostbyname(argv[1])) == NULL) { herror("gethostbyname出错!"); exit(1); } if((sock_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { perror("socket创建出错!"); exit(1); } serv_addr.sin_family=AF_INET; serv_addr.sin_port=htons(SERVPORT); serv_addr.sin_addr = *((struct in_addr *)host->h_addr); bzero(&(serv_addr.sin_zero),8); if(connect(sock_fd, (struct sockaddr *)&serv_addr, sizeof(struct sockaddr)) == -1) { perror("connect出错!"); exit(1); } if((recvbytes=recv(sock_fd, buf, MAXDATASIZE, 0)) == -1) { perror("recv出错!"); exit(1); } buf[recvbytes] = ' '; printf("Received: %s",buf); close(sock_fd); }
这段代码基本上和第一个一样,些许不同!
收藏的用户(0) X
正在加载信息~
推荐阅读
最新回复 (0)
站点信息
- 文章2281
- 用户1336
- 访客9607056
每日一句
Life is too short for us to wake up in the morning with regrets.
人生苦短,所以每天不要带着遗憾醒来。
人生苦短,所以每天不要带着遗憾醒来。
- Android Studio Arctic Fox | 2020.3.1使用问题
- NDK cmake报错:asm/types.h not found
- Android应用性能优化系列视图篇——隐藏在资源图片中的内存杀手
- CMake生成OpenCV解决方案&&编译OpenCV源码
- ImageView使用属性动画解决OOM问题
- Android App开发人员的8种必备技能
- 从simplepjsua.c示例程序了解PJSUA-LIB的基本使用流程
- 获取ElementUI Table排序后的数据
- iMessage for Android是我们需要的但不是我们想要的
- Linux系统查看CPU使用率的几个命令
- .a静态库创建与合并
- 关于百度网盘155010解决方法
- iOS公司账号($99)/企业账号($299)申请
新会员