(linux)客户端从服务器端获取一个文件

简介: (linux)客户端从服务器端获取一个文件 要求:服务器端传送一个文件(图像文件或文本文件)到客户端   解: 一:两台linux虚拟机之间 服务器: 1:     gcc server.c -o server 2:     .

(linux)客户端从服务器端获取一个文件

要求:服务器端传送一个文件(图像文件或文本文件)到客户端

 

解:

一:两台linux虚拟机之间
服务器:

1:     gcc server.c -o server

2:     ./server


客户端:

1:     gcc client.c -o client

2:     ./client 服务器端ip地址   例如:./client 192.168.20.131

3:     输入文件名


二:ubuntu虚拟机与arm学习板
1:     虚拟机上运行   gcc server.c -o server
2:     虚拟机上运行   arm-linux-gcc client.c -o client
3:     将client复制到arm学习板上,并在学习板上执行命令chmod 777 client
4:     在arm学习板上运行    ./client 服务器端ip地址    例如:./client 192.168.20.131
5:     在arm学习板上输入要从虚拟机(服务器)得到的文件名

 

/*server.c*/
#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <unistd.h>
#include <netinet/in.h>
#define PORT            4321
#define BUFFER_SIZE        1024
#define MAX_QUE_CONN_NM    5
/////////////////////////////////////////////////////
#define FILE_NAME_MAX_SIZE 512
/////////////////////////////////////////////////////
int main( )
{
    struct sockaddr_in server_sockaddr,client_sockaddr;
    int sin_size,recvbytes;
    int sockfd, client_fd;
    char buf[BUFFER_SIZE];
    
    /*建立socket连接*/
    if ((sockfd = socket(AF_INET,SOCK_STREAM,0))== -1)
    {
        perror("Create Socket Failed! \n");//创建套接字失败
        exit(1);
    }
    printf("Socket id = %d\n",sockfd);   //输出Socket描述符
    
    /*设置sockaddr_in 结构体中相关参数*/
    server_sockaddr.sin_family = AF_INET;
    server_sockaddr.sin_port = htons(PORT);
    server_sockaddr.sin_addr.s_addr = INADDR_ANY;
    bzero(&(server_sockaddr.sin_zero), 8);
    
    int i = 1;/* 允许重复使用本地地址与套接字进行绑定 */
    setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &i, sizeof(i));    
    
    /*绑定函数bind()*/  //将套接字绑定一个IP地址和端口号
    if (bind(sockfd, (struct sockaddr *)&server_sockaddr,sizeof(struct sockaddr)) == -1)
    {
        perror("Server Bind Failed! \n"); //套接口与本地ip地址和端口绑定失败
        exit(1);
    }
    printf("Bind success!\n");
    
    /*调用listen()函数,创建未处理请求的队列*/
    if (listen(sockfd, MAX_QUE_CONN_NM) == -1)
    {
        perror("Server Listen Failed! \n");   //套接字设置为监听状态失败
        exit(1);
    }
    printf("Listening....\n");
    
    
    /*调用accept()函数,阻塞等待客户端的连接请求*/
    if ((client_fd = accept(sockfd,(struct sockaddr *)&client_sockaddr, &sin_size)) == -1)
    {
        perror("Server Accept Failed! \n");   //接受连接失败
        exit(1);
    }

/////////////////////////////////////////////////////
    printf("Connected! \n");

    char buffer[BUFFER_SIZE];
    bzero(buffer,BUFFER_SIZE);
    if(recv(client_fd,buffer,BUFFER_SIZE,0)<0)
    {
        perror("Server Recieve Data Failed! \n");   //接收数据失败
        exit(1);
    }

    char file_name[FILE_NAME_MAX_SIZE+1];
    bzero(file_name,FILE_NAME_MAX_SIZE+1);
    //从buffer中拷贝文件名到file_name中
    strncpy(file_name,buffer,strlen(buffer)>FILE_NAME_MAX_SIZE?FILE_NAME_MAX_SIZE:strlen(buffer));
    printf("%s\n",file_name);

    FILE *fp=fopen(file_name,"r");  //打开文件准备读取文件
    if(NULL==fp)
    {
        printf("Not Found %s \n",file_name);   //没有找到文件
    }
    else
    {
        bzero(buffer,BUFFER_SIZE);   //将buffer清零
        int length=0;
        //每读取一段数据,便将其发送给客户端,循环直到文件读完为止
        while((length=fread(buffer,sizeof(char),BUFFER_SIZE,fp))>0)   //读取数据并缓存到buffer中
        {
            if(send(client_fd,buffer,length,0)<0)   //将buffer的数据发送到套接口
            {
                printf("Send File %s Failed. \n",file_name);//发送文件失败
                break;
            }
            bzero(buffer,BUFFER_SIZE);  //将buffer清零
        }
    
        fclose(fp);//关闭文件
        printf("File:%s  Transfer Successful! \n",file_name);
    }

    close(client_fd);//关闭与客户端的连接


/////////////////////////////////////////////////////

/***************************************************
    
    //调用recv()函数接收客户端的请求
    memset(buf , 0, sizeof(buf));
    if ((recvbytes = recv(client_fd, buf, BUFFER_SIZE, 0)) == -1)
    {
        perror("recv");
        exit(1);
    }
    printf("Received a message: %s\n", buf);

****************************************************/
    close(sockfd);//关闭监听用的socket
    return 0;     //正常退出
}
 

 

/*client.c*/

#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <unistd.h>
#include <netinet/in.h>
#include <netdb.h>
#define PORT    4321
#define BUFFER_SIZE 1024

/////////////////////////////////////////////////////
#define FILE_NAME_MAX_SIZE 512
/////////////////////////////////////////////////////

int main(int argc, char *argv[])
{
    int sockfd,sendbytes;
    char buf[BUFFER_SIZE];
    struct hostent *host;
    struct sockaddr_in serv_addr;
    
    if(argc < 2)
    {
        fprintf(stderr,"Usage: ./client Hostname(or ip address) \n");
        exit(1);
    }
    /*地址解析函数*/
    if ((host = gethostbyname(argv[1])) == NULL)
    {
        perror("Server IP Address Error. \n");
        exit(1);
    }
    
    memset(buf, 0, sizeof(buf));  //将buf全部填充0
//    sprintf(buf, "%s", argv[2]);  //将输入的第2个参数写到buf中
    /*创建socket*/
    if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1)
    {
        perror("Create Socket Failed! \n");//创建Socket失败
        exit(1);
    }
    
    /*设置sockaddr_in 结构体中相关参数*/
    serv_addr.sin_family = AF_INET;
    serv_addr.sin_port = htons(PORT);
    serv_addr.sin_addr = *((struct in_addr *)host->h_addr);
    bzero(&(serv_addr.sin_zero), 8);
    /*调用connect函数主动发起对服务器端的连接*/
    if(connect(sockfd,(struct sockaddr *)&serv_addr,sizeof(struct sockaddr))== -1)
    {
        perror("Connect To Server IP Failed! \n"); //连接服务器失败
        exit(1);
    }

/////////////////////////////////////////////////////
    printf("Connected! \n");
    char file_name[FILE_NAME_MAX_SIZE+1]; 
    bzero(file_name, FILE_NAME_MAX_SIZE+1);
    printf("Please Input File Name On Server:\t");
    scanf("%s",file_name);
    char buffer[BUFFER_SIZE];
    bzero(buffer,BUFFER_SIZE);

    //复制文件名到buffer中
    strncpy(buffer,file_name,strlen(file_name)>BUFFER_SIZE?BUFFER_SIZE:strlen(file_name));

    if(send(sockfd,buffer,BUFFER_SIZE,0)<0) //向服务器发送buffer中的数据,即发送文件名给服务器
    {
        perror("Send File Name Failed! \n");  //发送文件名给服务器失败
        exit(1);
    }

    FILE *fp=fopen(file_name,"w"); //打开文件,准备写入
    if(NULL==fp)
    {
        printf("File %s Can Not Open To Write! \n",file_name);//新建或打开文件进行写操作失败
        exit(1);
    }

    bzero(buffer,BUFFER_SIZE);
    int length=0;
    while((length=recv(sockfd,buffer,BUFFER_SIZE,0)) >0)   //将从服务器接收数据缓存到buffer中
    {        //每接收一段数据,便将其写入文件中,循环直到文件接收并写完为止
        if(fwrite(buffer,sizeof(char),length,fp)<length) 
        {    //如果实际写入的字节数少于服务器传来的字节数,则写入错误
            printf("File %s Write Failed! \n",file_name);//文件写入失败
            break;
        }
        bzero(buffer,BUFFER_SIZE);   //将buffe清零
    }
    printf("Receive File: %s  \n",file_name);  //从服务器得到文件:%s
    fclose(fp);   //关闭文件

/////////////////////////////////////////////////////

/***************************************************
    //发送消息给服务器端
    if ((sendbytes = send(sockfd, buf, strlen(buf), 0)) == -1)
    {
        perror("send");
        exit(1);
    }
****************************************************/
    close(sockfd);    //关闭Socket
    exit(0);          //正常退出
}

原文地址https://blog.csdn.net/Chenger_32123/article/details/81332141

相关文章
|
1天前
|
存储 开发工具 git
[Git] 深入理解 Git 的客户端与服务器角色
Git 的核心设计理念是分布式,每个仓库既可以是客户端也可以是服务器。通过 GitHub 远程仓库和本地仓库的协作,Git 实现了高效的版本管理和代码协作。GitHub 作为远程裸仓库,存储项目的完整版本历史并支持多客户端协作;本地仓库则通过 `.git` 文件夹独立管理版本历史,可在离线状态下进行提交、回滚等操作,并通过 `git pull` 和 `git push` 与远程仓库同步。这种分布式特性使得 Git 在代码协作中具备强大的灵活性和可靠性。
37 18
[Git] 深入理解 Git 的客户端与服务器角色
|
6天前
|
存储 安全 网络安全
服务器感染了.baxia勒索病毒,如何确保数据文件完整恢复?
近年来,勒索病毒如.baxia不断演变,利用漏洞、社交工程等手段加密文件,威胁范围扩大。加密货币的兴起使其支付方式更匿名,追踪困难。技术支持尤为重要,添加技术服务号(shuju315),专业团队提供数据恢复方案。面对复杂解密要求,包括赎金支付、个人信息提供和执行特定操作,需保持冷静并寻求帮助。防御措施包括加强安全意识、定期备份数据、安装杀毒软件、避免未知文件、更新系统及制定应急响应计划。
35 11
|
1月前
|
存储 人工智能 自然语言处理
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
ChatMCP 是一款基于模型上下文协议(MCP)的 AI 聊天客户端,支持多语言和自动化安装。它能够与多种大型语言模型(LLM)如 OpenAI、Claude 和 OLLama 等进行交互,具备自动化安装 MCP 服务器、SSE 传输支持、自动选择服务器、聊天记录管理等功能。
205 15
ChatMCP:基于 MCP 协议开发的 AI 聊天客户端,支持多语言和自动化安装 MCP 服务器
|
9天前
|
安全 大数据 Linux
云上体验最佳的服务器操作系统 - Alibaba Cloud Linux | 飞天技术沙龙-CentOS 迁移替换专场
本次方案的主题是云上体验最佳的服务器操作系统 - Alibaba Cloud Linux ,从 Alibaba Cloud Linux 的产生背景、产品优势以及云上用户使用它享受的技术红利等方面详细进行了介绍。同时,通过国内某社交平台、某快递企业、某手机客户大数据业务 3 大案例,成功助力客户实现弹性扩容能力提升、性能提升、降本增效。 1. 背景介绍 2. 产品介绍 3. 案例分享
|
1月前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
75 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
27天前
|
Ubuntu Linux Go
golang编译成Linux可运行文件
本文介绍了如何在 Linux 上编译和运行 Golang 程序,涵盖了本地编译和交叉编译的步骤。通过这些步骤,您可以轻松地将 Golang 程序编译成适合 Linux 平台的可执行文件,并在目标服务器上运行。掌握这些技巧,可以提高开发和部署 Golang 应用的效率。
202 14
|
26天前
|
运维 监控 Linux
推荐几个不错的 Linux 服务器管理工具
推荐几个不错的 Linux 服务器管理工具
123 6
|
26天前
|
存储 NoSQL Linux
linux积累-core文件是干啥的
核心文件是Linux系统在程序崩溃时生成的重要调试文件,通过分析核心文件,开发者可以找到程序崩溃的原因并进行调试和修复。本文详细介绍了核心文件的生成、配置、查看和分析方法
87 6
|
28天前
|
存储 NoSQL Linux
linux之core文件如何查看和调试
通过设置和生成 core 文件,可以在程序崩溃时获取详细的调试信息。结合 GDB 等调试工具,可以深入分析 core 文件,找到程序崩溃的具体原因,并进行相应的修复。掌握这些调试技巧,对于提高程序的稳定性和可靠性具有重要意义。
251 6
W9
|
2月前
|
运维 关系型数据库 MySQL
轻松管理Linux服务器的5个优秀管理面板
Websoft9 应用管理平台,github 2k star 开源软件,既有200+的优秀开源软件商店,一键安装。又有可视化的Linux管理面板,文件、数据库、ssl证书方便快捷管理。
W9
199 1