C 套接字程序文件传输

C 套接字程序文件传输,c,linux,sockets,C,Linux,Sockets,当我使用下面的代码传输二进制文件时,只传输了文件的一半。当我在使用相同二进制文件的环回地址时检查相同的代码时,它工作正常,即整个文件被传输 以下代码或我的网络是否有任何问题 客户c: #include<stdlib.h> #include<stdio.h> #include<errno.h> #include<string.h> #include<sys/types.h> #include<netinet/in.h> #in

当我使用下面的代码传输二进制文件时,只传输了文件的一半。当我在使用相同二进制文件的环回地址时检查相同的代码时,它工作正常,即整个文件被传输

以下代码或我的网络是否有任何问题

客户c:

#include<stdlib.h>
#include<stdio.h>
#include<errno.h>
#include<string.h>
#include<sys/types.h>
#include<netinet/in.h>
#include<sys/wait.h>
#include<sys/socket.h>
#include<signal.h>
#include<ctype.h>          
#include<arpa/inet.h>
#include<netdb.h>
#define PORT 20000
#define LENGTH 512

void error(const char *msg)
{
    perror(msg);
    exit(1);
}

int main(int argc, char *argv[])
{
    /* Variable Definition */
    int sockfd, nsockfd;
    char revbuf[LENGTH]; 
    struct sockaddr_in remote_addr;

    /* Get the Socket file descriptor */
    if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
        fprintf(stderr, "ERROR: Failed to obtain Socket Descriptor! (errno = %d)\n",errno);
        exit(1);
    }

    /* Fill the socket address struct */
    remote_addr.sin_family = AF_INET; 
    remote_addr.sin_port = htons(PORT); 
    inet_pton(AF_INET, "192.168.103.190", &remote_addr.sin_addr); 
    //inet_pton(AF_INET, "192.168.103.179", &remote_addr.sin_addr);
    bzero(&(remote_addr.sin_zero), 8);

    /* Try to connect the remote */
    if (connect(sockfd, (struct sockaddr *)&remote_addr, sizeof(struct sockaddr)) == -1) {
        fprintf(stderr, "ERROR: Failed to connect to the host! (errno = %d)\n",errno);
        exit(1);
    }
    else
        printf("[Client] Connected to server at port %d...ok!\n", PORT);

    /*send to server*/
    char* fs_name = "/usr/local/context.2848";
    char sdbuf[LENGTH]; 
    printf("[Client] Sending %s to the Server... ", fs_name);
    FILE *fs = fopen(fs_name, "r");
    if(fs == NULL) {
        printf("ERROR: File %s not found.\n", fs_name);
        exit(1);
    }
    bzero(sdbuf, LENGTH); 
    int fs_block_sz,i=0; 
    while((fs_block_sz = fread(sdbuf, sizeof(char), LENGTH, fs)) > 0) {
        printf("Data Sent %d = %d\n",i,fs_block_sz);
        if(send(sockfd, sdbuf, fs_block_sz, 0) < 0) {
            fprintf(stderr, "ERROR: Failed to send file %s. (errno = %d)\n", fs_name,     errno);
            exit(1);
        }
        bzero(sdbuf, LENGTH);
        i++;
    }
    close (sockfd);
    printf("[Client] Connection lost.\n");
    return (0);
}
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#定义端口20000
#定义长度512
无效错误(常量字符*消息)
{
佩罗尔(味精);
出口(1);
}
int main(int argc,char*argv[])
{
/*变量定义*/
int sockfd,nsockfd;
char revbuf[长度];
远程地址中的结构sockaddr\u;
/*获取套接字文件描述符*/
if((sockfd=socket(AF_INET,SOCK_STREAM,0))=-1){
fprintf(stderr,“错误:获取套接字描述符失败!(errno=%d)\n”,errno);
出口(1);
}
/*填充套接字地址结构*/
远程地址sin家庭=AF网络;
远程地址sin\u端口=htons(端口);
inet\u pton(AF\u inet,“192.168.103.190”和远程地址sin\u addr);
//inet\u pton(AF\u inet,“192.168.103.179”和远程地址sin\u addr);
bzero(&(远程地址sinu zero),8);
/*尝试连接遥控器*/
if(connect(sockfd,(struct sockaddr*)和remote_addr,sizeof(struct sockaddr))=-1){
fprintf(stderr,“错误:无法连接到主机!(errno=%d)\n”,errno);
出口(1);
}
其他的
printf(“[客户端]在端口%d连接到服务器…正常!\n”,端口);
/*发送到服务器*/
char*fs_name=“/usr/local/context.2848”;
字符sdbuf[长度];
printf(“[客户端]正在将%s发送到服务器…”,fs_名称);
FILE*fs=fopen(fs_名称,“r”);
如果(fs==NULL){
printf(“错误:找不到文件%s。\n”,fs\U名称);
出口(1);
}
bzero(sdbuf,长度);
int fs_block_sz,i=0;
而((fs_block_sz=fread(sdbuf,sizeof(char),LENGTH,fs))>0){
printf(“发送的数据%d=%d\n”,i,fs\u block\u sz);
如果(发送(sockfd,sdbuf,fs_block_sz,0)<0){
fprintf(stderr,“错误:发送文件%s失败。(错误号=%d)\n”,fs\u名称,错误号);
出口(1);
}
bzero(sdbuf,长度);
i++;
}
关闭(sockfd);
printf(“[客户端]连接丢失。\n”);
返回(0);
}
服务器.c

#include<stdlib.h>
#include<stdio.h>
#include<errno.h>
#include<string.h>
#include<sys/types.h>
#include<netinet/in.h>
#include<sys/wait.h>
#include<sys/socket.h>
#include<signal.h>
#include<ctype.h>          
#include<arpa/inet.h>
#include<netdb.h>
#define PORT 20000 
#define BACKLOG 5
#define LENGTH 512 

void error(const char *msg)
{
    perror(msg);
    exit(1);
}

int main ()
{
    /* Defining Variables */
    int sockfd, nsockfd; 
    int num;
    int sin_size; 
    struct sockaddr_in addr_local; /* client addr */
    struct sockaddr_in addr_remote; /* server addr */
    char revbuf[LENGTH]; // Receiver buffer

    /* Get the Socket file descriptor */
    if((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1 ) {
        fprintf(stderr, "ERROR: Failed to obtain Socket Descriptor. (errno = %d)\n", errno);
        exit(1);
    }
    else 
        printf("[Server] Obtaining socket descriptor successfully.\n");

    /* Fill the client socket address struct */
    addr_local.sin_family = AF_INET; // Protocol Family
    addr_local.sin_port = htons(PORT); // Port number
    addr_local.sin_addr.s_addr = INADDR_ANY; // AutoFill local address
    bzero(&(addr_local.sin_zero), 8); // Flush the rest of struct

    /* Bind a special Port */
    if( bind(sockfd, (struct sockaddr*)&addr_local, sizeof(struct sockaddr)) == -1 ) {
        fprintf(stderr, "ERROR: Failed to bind Port. (errno = %d)\n", errno);
        exit(1);
    }
    else 
        printf("[Server] Binded tcp port %d in addr 127.0.0.1 sucessfully.\n",PORT);

    /* Listen remote connect/calling */
    if(listen(sockfd,BACKLOG) == -1) {
        fprintf(stderr, "ERROR: Failed to listen Port. (errno = %d)\n", errno);
        exit(1);
    }
    else
        printf ("[Server] Listening the port %d successfully.\n", PORT);

    int success = 0;
    while(success == 0)
    {
        sin_size = sizeof(struct sockaddr_in);

        /* Wait a connection, and obtain a new socket file despriptor for single connection */
        if ((nsockfd = accept(sockfd, (struct sockaddr *)&addr_remote, &sin_size)) == -1) {
            fprintf(stderr, "ERROR: Obtaining new Socket Despcritor. (errno = %d)\n", errno);
            exit(1);
        }
        else 
            printf("[Server] Server has got connected from %s.\n", inet_ntoa(addr_remote.sin_addr));
        /*Receive File from Client */
        char* fr_name = "/home/ankita/context.2848";
        FILE *fr = fopen(fr_name, "a");
        if(fr == NULL)
            printf("File %s Cannot be opened file on server.\n", fr_name);
        else {
            bzero(revbuf, LENGTH); 
            int fr_block_sz = 0;
            int i=0;
            while((fr_block_sz = recv(nsockfd, revbuf, LENGTH, 0)) > 0) {
                printf("Data Received %d = %d\n",i,fr_block_sz);
                int write_sz = fwrite(revbuf, sizeof(char), fr_block_sz, fr);
                if(write_sz < fr_block_sz)
                    error("File write failed on server.\n");
                bzero(revbuf, LENGTH);
                i++;
            }
            if(fr_block_sz < 0) {
                if (errno == EAGAIN)
                    printf("recv() timed out.\n");
                else {
                    fprintf(stderr, "recv() failed due to errno = %d\n", errno);
                    exit(1);
                }
            }
            printf("Ok received from client!\n");
            fclose(fr); 
        }
        success = 1;
    }
}   
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#包括
#定义端口20000
#定义待办事项5
#定义长度512
无效错误(常量字符*消息)
{
佩罗尔(味精);
出口(1);
}
int main()
{
/*定义变量*/
int sockfd,nsockfd;
int-num;
国际标准尺寸;
addr\u local中的struct sockaddr\u;/*客户端地址*/
addr_remote中的struct sockaddr_;/*服务器地址*/
char revbuf[LENGTH];//接收器缓冲区
/*获取套接字文件描述符*/
if((sockfd=socket(AF_INET,SOCK_STREAM,0))=-1){
fprintf(stderr,“错误:获取套接字描述符失败。(errno=%d)\n”,errno);
出口(1);
}
其他的
printf(“[Server]成功获取套接字描述符。\n”);
/*填充客户端套接字地址结构*/
addr\u local.sin\u family=AF\u INET;//协议族
addr_local.sin_port=htons(port);//端口号
addr\u local.sin\u addr.s\u addr=INADDR\u ANY;//自动填充本地地址
bzero(&(addr_local.sin_zero),8);//刷新结构的其余部分
/*绑定特殊端口*/
if(bind(sockfd,(struct sockaddr*)和addr_local,sizeof(struct sockaddr))=-1){
fprintf(stderr,“错误:绑定端口失败。(errno=%d)\n”,errno);
出口(1);
}
其他的
printf(“[Server]成功绑定了addr 127.0.0.1中的tcp端口%d。\n”,端口);
/*监听远程连接/呼叫*/
如果(侦听(sockfd,BACKLOG)=-1){
fprintf(stderr,“错误:侦听端口失败。(errno=%d)\n”,errno);
出口(1);
}
其他的
printf(“[Server]已成功侦听端口%d。\n”,端口);
int成功=0;
while(成功==0)
{
sin_size=sizeof(结构sockaddr_in);
/*等待连接,并为单个连接获取新的套接字文件despriptor*/
if((nsockfd=accept(sockfd,(struct sockaddr*)&addr\u remote,&sin\u size))=-1){
fprintf(stderr,“错误:获取新套接字解压器。(errno=%d)\n”,errno);
出口(1);
}
其他的
printf(“[Server]服务器已从%s连接。\n”,inet_ntoa(addr_remote.sin_addr));
/*从客户端接收文件*/
char*fr_name=“/home/ankita/context.2848”;
文件*fr=fopen(fr_名称,“a”);
如果(fr==NULL)
printf(“无法在服务器上打开文件%s。\n”,fr\u名称);
否则{
bzero(revbuf,长度);
int fr_block_sz=0;
int i=0;
而((fr_block_sz=recv(nsockfd,revbuf,LENGTH,0))>0){
printf(“收到的数据%d=%d\n”,i,fr\u block\u sz);
int write_sz=fwrite(revbuf,sizeof(char),fr_block_sz,fr);
if(写入_sz
发送并不保证发送您要求它发送的所有数据,它可能会发送更少的数据。您只检查发送的错误,而不是它发送的比您预期的少。recv是一样的。因此,在实现的两个方面都有相同的bug。对于localhost,您可能会像内核一样侥幸逃脱
fr_block_sz == 0