linux 网络编程:客户端与服务器通过TCP协议相互通信
来源:互联网 发布:2017手机号段数据库 编辑:程序博客网 时间:2024/06/05 18:50
1、TCP编程的客户端一般步骤:
1、创建一个socket,用函数socket();
2、设置socket属性,用函数setsockopt();* 可选;
3、绑定IP地址、端口等信息到socket上,用函数bind();* 可选;
4、设置要连接的对方的IP地址和端口等属性;
5、连接服务器,用函数connect();
6、收发数据,用函数send()和recv(),或者read()和write();
7、关闭网络连接;
2、TCP编程的服务器端一般步骤:
1、创建一个socket,用函数socket();
2、设置socket属性,用函数setsockopt(); * 可选;
3、绑定IP地址、端口等信息到socket上,用函数bind();
4、开启监听,用函数listen();
5、接收客户端上来的连接,用函数accept();
6、收发数据,用函数send()和recv(),或者read()和write();
7、关闭网络连接;
8、关闭监听; 3、客户端源代码(tcpclient.c):
4、服务器源代码(tcpserver.c):
1、创建一个socket,用函数socket();
2、设置socket属性,用函数setsockopt();* 可选;
3、绑定IP地址、端口等信息到socket上,用函数bind();* 可选;
4、设置要连接的对方的IP地址和端口等属性;
5、连接服务器,用函数connect();
6、收发数据,用函数send()和recv(),或者read()和write();
7、关闭网络连接;
2、TCP编程的服务器端一般步骤:
1、创建一个socket,用函数socket();
2、设置socket属性,用函数setsockopt(); * 可选;
3、绑定IP地址、端口等信息到socket上,用函数bind();
4、开启监听,用函数listen();
5、接收客户端上来的连接,用函数accept();
6、收发数据,用函数send()和recv(),或者read()和write();
7、关闭网络连接;
8、关闭监听; 3、客户端源代码(tcpclient.c):
#include <stdio.h>
#include <string.h>
#include <errno.h>
#include <sys/socket.h>
#include <stdlib.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#define MAXBUF 512
int main(int argc, char **argv)
{
int sockfd, len;
struct sockaddr_in server_addr;
char buffer[MAXBUF + 1];
if (argc != 3) {
printf("参数正确格式如下:\nIP地址 端口\n127.0.0.1 4567\n");
exit(0);
}
/* 创建一个 socket 用于 tcp 通信 */
if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
perror("Socket");
exit(errno);
}
printf("socket created\n");
/* 初始化服务器端(对方)的地址和端口信息 */
bzero(&server_addr, sizeof(server_addr));
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(atoi(argv[2]));
if (inet_aton(argv[1], (struct in_addr *) &server_addr.sin_addr.s_addr) == 0) {
perror(argv[1]);
exit(errno);
}
/* 连接服务器 */
if (connect(sockfd, (struct sockaddr *) &server_addr, sizeof(server_addr)) != 0) {
perror("Connect failure");
exit(errno);
}
printf("server connected\n");
/* 接收对方发过来的消息,最多接收 MAXBUF 个字节 */
bzero(buffer, MAXBUF + 1);
/* 接收服务器来的消息 */
len = recv(sockfd, buffer, MAXBUF, 0);
if(len > 0)
printf("接收消息成功:'%s',共%d个字节的数据\n", buffer, len);
else
printf("消息接收失败!错误代码是%d,错误信息是'%s'\n", errno, strerror(errno));
bzero(buffer, MAXBUF + 1);
strcpy(buffer, "客户端发给服务器端的消息\n");
/* 发消息给服务器 */
len = send(sockfd, buffer, strlen(buffer), 0);
if(len < 0)
printf("发送失败!错误代码是%d,错误信息是'%s'\n", errno, strerror(errno));
else
printf("发送成功,共发送了%d个字节!\n", len);
/* 关闭连接 */
close(sockfd);
return 0;
}
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <sys/socket.h>
#include <sys/wait.h>
#include <unistd.h>
#include <arpa/inet.h>
#define MAXBUF 512
int main(int argc, char **argv)
{
int sockfd, new_fd;
socklen_t len;
struct sockaddr_in server_addr, client_addr;
unsigned int port, num;
char buf[MAXBUF + 1];
if (argv[1])
port = atoi(argv[1]);
else
port = 5678;
if (argv[2])
num = atoi(argv[2]);
else
num = 3;
if ((sockfd = socket(PF_INET, SOCK_STREAM, 0)) == -1) {
perror("socket");
exit(1);
}
else printf("socket created success!!!\n");
bzero(&server_addr, sizeof(server_addr));
server_addr.sin_family = PF_INET;
server_addr.sin_port = htons(port);
if(argv[3])
server_addr.sin_addr.s_addr = inet_addr(argv[3]);
else
server_addr.sin_addr.s_addr = INADDR_ANY;
if (bind(sockfd, (struct sockaddr *) &server_addr, sizeof(struct sockaddr)) == -1) {
perror("bind");
exit(1);
}else
printf("binded success!!!\n");
if (listen(sockfd, num) == -1) {
perror("listen");
exit(1);
}else
printf("Let's listen\n");
while(1) {
len = sizeof(struct sockaddr);
if ((new_fd = accept(sockfd, (struct sockaddr *)&client_addr, &len)) == -1) {
perror("accept");
exit(errno);
}else
printf("client connect the server now: client %s, port %d, new socket %d\n",inet_ntoa(client_addr.sin_addr), ntohs(client_addr.sin_port), new_fd);
/* 开始处理每个新连接上的数据收发 */
bzero(buf, MAXBUF + 1);
strcpy(buf, "服务器发给客户端的消息\n只能向new_fd这个用accept函数新建立的socket发消息,不能向sockfd这个监听socket发送消息,监听socket不能用来接收或发送消息\n");
/* 发消息给客户端 */
len = send(new_fd, buf, strlen(buf), 0);
if(len < 0) {
printf("消息发送失败!错误代码是%d,错误信息是'%s'\n", errno, strerror(errno));
}else
printf("消息发送成功,共发送了%d个字节!\n", len);ss
bzero(buf, MAXBUF + 1);
/* 接收客户端的消息 */
len = recv(new_fd, buf, MAXBUF, 0);
if(len > 0)
printf("接收成功:'%s',共%d个字节的数据\n", buf, len);
else
printf("接收失败!错误代码是%d,错误信息是'%s'\n", errno, strerror(errno));
/* 处理每个新连接上的数据收发结束 */
}
close(sockfd);
return 0;
}
转自:http://renwen0524.blog.163.com/blog/static/7301945520116611156215/
- linux 网络编程:客户端与服务器通过TCP协议相互通信 + UDP
- linux 网络编程:客户端与服务器通过TCP协议相互通信
- linux 网络编程:客户端与服务器通过TCP协议相互通信
- 【Linux网络编程实例】实例二:利用TCP协议进行客户端与服务器通信
- Linux 网络编程实现TCP协议下的服务器客户端通信
- TCP服务器客户端网络通信
- TCP服务器、客户端之间的相互通信
- linux c之网络编程之TCP(服务器和和客户端基础通信)
- android TCP客户端通过socket与服务器通信
- Linux网络编程-客户端与服务器端通信
- c++做服务器,java当客户端,采用 tcp协议之相互通信demo
- linux网络通信-----TCP协议
- linux 网络编程之最简单的tcp通信客户端
- Linux网络编程(二)TCP协议通信
- Linux下网络编程之自定义协议进行并发多客户端与服务器的通信(多进程处理并发)不足占用资源太多
- Linux下网络socket编程——实现服务器(select)与多个客户端通信
- linux网络编程--服务器客户端(TCP实现)
- Linux TCP UDP网络编程客户端和服务器
- JavaWeb 服务启动时,在后台启动加载一个线程
- 游戏截屏
- 在Linux上编译安装apache http server
- 基于vs2010的远程调试方法
- android 正则表达式 判断邮箱格式是否正确
- linux 网络编程:客户端与服务器通过TCP协议相互通信
- 【转】mysql5.0.x统计每秒增删改查替换数及系统每秒磁盘IO
- 运维
- Tomcat的优化配置
- C/C++ 误区一:void main()
- java GUI
- 面试基础题系列(二)java 打印 ,杨辉三角
- 获取JPasswordfield内容的方法
- js判断手机访问网站自动跳转到手机版