#include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <errno.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #define BUFFER_SIZE 1024 int main(int argc, char *argv[]) { int client_socket; struct sockaddr_in server_addr; char buffer[BUFFER_SIZE]; char *server_ip = "127.0.0.1"; int port = 8888; if(argc > 2) { server_ip = argv[1]; port = atoi(argv[2]); } client_socket = socket(AF_INET, SOCK_STREAM, 0); if(client_socket == -1) { perror("socket"); exit(EXIT_FAILURE); } memset(&server_addr, 0, sizeof(server_addr)); server_addr.sin_family = AF_INET; server_addr.sin_addr.s_addr = inet_addr(server_ip); server_addr.sin_port = htons(port); if(connect(client_socket, (struct sockaddr *)&server_addr, sizeof(server_addr)) == -1) { perror("connect"); exit(EXIT_FAILURE); } printf("Connected to server %s:%d\n", server_ip, port); while(1) { fgets(buffer, BUFFER_SIZE, stdin); buffer[strlen(buffer) - 1] = '\0'; if(strcmp(buffer, "quit") == 0) { break; } int send_len = send(client_socket, buffer, strlen(buffer), 0); if(send_len == -1) { perror("send"); break; } } close(client_socket); return 0; }
时间: 2024-04-05 10:30:01 浏览: 56
这是一个基于 TCP 协议的客户端程序,它可以连接到指定的服务器,并向服务器发送数据。程序首先创建一个客户端套接字,然后通过指定的 IP 地址和端口号连接到服务器。连接成功后,程序进入一个循环,不断从标准输入读取用户输入的数据,并将其发送给服务器。如果用户输入了 "quit",则程序结束循环并关闭客户端套接字。如果发送数据出现错误,程序也会退出循环并关闭套接字。
需要注意的是,这个程序没有对从服务器接收到的数据进行处理,因此它只能向服务器发送数据,而不能从服务器接收数据。如果需要实现双向通信,需要修改程序以接收从服务器发送来的数据。
相关问题
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/socket.h> #include <arpa/inet.h>分别有什么作用
这些引用中包含了C语言的头文件,这些头文件中定义了一些函数和变量,可以在程序中使用。具体来说:
- #include <stdio.h>:定义了输入输出函数,例如printf和scanf。
- #include <stdlib.h>:定义了一些通用的函数,例如malloc和free,用于动态内存分配和释放。
- #include <string.h>:定义了一些字符串处理函数,例如strcpy和strcat。
- #include <unistd.h>:定义了一些系统调用函数,例如fork和execve。
- #include <sys/socket.h>:定义了一些网络编程相关的函数和数据结构,例如socket和sockaddr。
- #include <arpa/inet.h>:定义了一些网络字节序和主机字节序之间的转换函数,例如htonl和ntohs。
这些头文件中的函数和变量可以帮助程序员更方便地编写程序,提高程序的可读性和可维护性。
虚拟机centos没有那个文件或目录 #include <winsock2.h>该怎么办
`#include <winsock2.h>` 是 Windows 平台的头文件,如果你在 CentOS 虚拟机上编译程序,应该使用 Linux 平台的头文件。具体来说,你需要包含 `<sys/socket.h>`、`<netinet/in.h>` 和 `<arpa/inet.h>` 这三个头文件来使用 Linux 平台的套接字 API。
另外,Linux 平台的套接字 API 在使用时需要链接 `libsocket` 库(或者 `libws2_32` 库,如果你在 Windows 平台上编译程序的话需要链接 `ws2_32.lib` 库)。你可以在编译时加上 `-lsocket` 参数来链接 `libsocket` 库,例如:
```
gcc -o server server.c -lsocket
```
以下是一个在 CentOS 上使用 Linux 平台的套接字 API 实现的服务器示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
int main() {
int server_socket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); // 创建套接字
if (server_socket < 0) {
perror("socket");
return 1;
}
struct sockaddr_in server_addr;
server_addr.sin_family = AF_INET;
server_addr.sin_addr.s_addr = htonl(INADDR_ANY);
server_addr.sin_port = htons(8000);
int iResult = bind(server_socket, (struct sockaddr*)&server_addr, sizeof(server_addr)); // 绑定套接字
if (iResult < 0) {
perror("bind");
close(server_socket);
return 1;
}
iResult = listen(server_socket, SOMAXCONN); // 监听套接字
if (iResult < 0) {
perror("listen");
close(server_socket);
return 1;
}
printf("服务器已启动,等待连接...\n");
int counter = 0;
while (1) {
struct sockaddr_in client_addr;
socklen_t client_addr_len = sizeof(client_addr);
int client_socket = accept(server_socket, (struct sockaddr*)&client_addr, &client_addr_len); // 接受客户端连接
if (client_socket < 0) {
perror("accept");
close(server_socket);
return 1;
}
counter++; // 每当有一个新的客户端连接时,计数器加1
printf("客户端 %s:%d 已连接,是今天的第 %d 个客户端。\n", inet_ntoa(client_addr.sin_addr), ntohs(client_addr.sin_port), counter);
char reply[1024];
sprintf(reply, "你是今天第%d个客户端", counter);
send(client_socket, reply, strlen(reply), 0); // 发送回复消息
close(client_socket);
}
close(server_socket);
return 0;
}
```
在 Linux 平台上,我们使用了 `socklen_t` 类型来表示套接字地址结构体的大小。另外,我们使用了 `close()` 函数来关闭套接字连接。
阅读全文