用C语言编写程序,有关网络编程文件传输,客户端接收文件,服务端有一个共享文件夹,当客户端和服务端连接后,客户端可以向服务端输入命令,如:列出共享文件夹下的所有文件,打开某文件等。服务端接收到命令后执行命令。共享的文件可以在客户端看到在Linux系统上运行
时间: 2024-03-11 17:49:19 浏览: 76
好的,您的问题是关于网络编程文件传输和客户端与服务端通信的C语言程序编写。
首先,您需要使用socket API来建立客户端和服务端的连接,使用TCP或UDP协议进行通信。此外,您需要了解Linux文件系统和命令行操作,以便在服务端接收到命令后能够正确执行。
下面是一个简单的C语言程序示例,其中客户端可以向服务端发送命令并接收服务端的回复,服务端可以接收命令并执行相关操作。
客户端代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#define BUFFER_SIZE 1024
int main(int argc, char *argv[]) {
// 创建socket
int sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0) {
perror("socket error");
exit(EXIT_FAILURE);
}
// 设置服务端地址
struct sockaddr_in servaddr;
memset(&servaddr, 0, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_port = htons(8888);
servaddr.sin_addr.s_addr = inet_addr("127.0.0.1");
// 连接服务端
if (connect(sockfd, (struct sockaddr *)&servaddr, sizeof(servaddr)) < 0) {
perror("connect error");
exit(EXIT_FAILURE);
}
// 接收服务端欢迎信息
char buffer[BUFFER_SIZE];
memset(buffer, 0, sizeof(buffer));
if (recv(sockfd, buffer, sizeof(buffer), 0) < 0) {
perror("recv error");
exit(EXIT_FAILURE);
}
printf("%s\n", buffer);
// 循环输入命令并接收回复
while (1) {
printf("请输入命令:");
memset(buffer, 0, sizeof(buffer));
fgets(buffer, sizeof(buffer), stdin);
buffer[strlen(buffer) - 1] = '\0';
if (send(sockfd, buffer, strlen(buffer), 0) < 0) {
perror("send error");
exit(EXIT_FAILURE);
}
if (strcmp(buffer, "exit") == 0) {
printf("客户端已退出\n");
break;
}
memset(buffer, 0, sizeof(buffer));
if (recv(sockfd, buffer, sizeof(buffer), 0) < 0) {
perror("recv error");
exit(EXIT_FAILURE);
}
printf("%s\n", buffer);
}
// 关闭socket
close(sockfd);
return 0;
}
```
服务端代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <dirent.h>
#define BUFFER_SIZE 1024
void list_dir(int sockfd) {
char buffer[BUFFER_SIZE];
memset(buffer, 0, sizeof(buffer));
DIR *dir;
struct dirent *entry;
if ((dir = opendir(".")) == NULL) {
sprintf(buffer, "无法打开目录\n");
if (send(sockfd, buffer, strlen(buffer), 0) < 0) {
perror("send error");
exit(EXIT_FAILURE);
}
return;
}
while ((entry = readdir(dir)) != NULL) {
if (entry->d_name[0] != '.') {
strcat(buffer, entry->d_name);
strcat(buffer, "\n");
}
}
if (send(sockfd, buffer, strlen(buffer), 0) < 0) {
perror("send error");
exit(EXIT_FAILURE);
}
}
int main(int argc, char *argv[]) {
// 创建socket
int listenfd = socket(AF_INET, SOCK_STREAM, 0);
if (listenfd < 0) {
perror("socket error");
exit(EXIT_FAILURE);
}
// 设置服务端地址
struct sockaddr_in servaddr;
memset(&servaddr, 0, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_port = htons(8888);
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
// 绑定端口
if (bind(listenfd, (struct sockaddr *)&servaddr, sizeof(servaddr)) < 0) {
perror("bind error");
exit(EXIT_FAILURE);
}
// 监听端口
if (listen(listenfd, 5) < 0) {
perror("listen error");
exit(EXIT_FAILURE);
}
printf("服务端已启动,等待客户端连接...\n");
// 循环接收客户端连接
int connfd;
struct sockaddr_in cliaddr;
memset(&cliaddr, 0, sizeof(cliaddr));
socklen_t clilen = sizeof(cliaddr);
while (1) {
connfd = accept(listenfd, (struct sockaddr *)&cliaddr, &clilen);
if (connfd < 0) {
perror("accept error");
continue;
}
printf("客户端 %s:%d 已连接\n", inet_ntoa(cliaddr.sin_addr), ntohs(cliaddr.sin_port));
// 发送欢迎信息
char buffer[BUFFER_SIZE];
memset(buffer, 0, sizeof(buffer));
sprintf(buffer, "欢迎连接到服务端!");
if (send(connfd, buffer, strlen(buffer), 0) < 0) {
perror("send error");
exit(EXIT_FAILURE);
}
// 循环接收命令并执行
while (1) {
memset(buffer, 0, sizeof(buffer));
if (recv(connfd, buffer, sizeof(buffer), 0) < 0) {
perror("recv error");
exit(EXIT_FAILURE);
}
if (strcmp(buffer, "exit") == 0) {
printf("客户端 %s:%d 已断开连接\n", inet_ntoa(cliaddr.sin_addr), ntohs(cliaddr.sin_port));
break;
} else if (strcmp(buffer, "ls") == 0) {
list_dir(connfd);
} else {
sprintf(buffer, "未知命令:%s\n", buffer);
if (send(connfd, buffer, strlen(buffer), 0) < 0) {
perror("send error");
exit(EXIT_FAILURE);
}
}
}
// 关闭客户端连接
close(connfd);
}
// 关闭socket
close(listenfd);
return 0;
}
```
其中,客户端可以输入命令 "ls" 来列出服务端共享文件夹下的所有文件。服务端使用 opendir 和 readdir 函数实现文件夹遍历,将文件名发送给客户端。
阅读全文