我想问一下,为什么我不能将文件从服务器传输到客户端? 当我开始从服务器发送文件时,客户端程序将有问题。 所以,我花了一些时间检查代码, 但我仍然无法找出问题所在 有谁可以为我指出问题?
CLIENTFILE.C
#include stdio.h
#include stdlib.h
#include time.h
#include netinet/in.h
#include fcntl.h
#include sys/types.h
#include string.h
#include stdarg.h
#define PORT 5678
#define MLEN 1000
int main(int argc, char *argv [])
{
int sockfd;
int number,message;
char outbuff[MLEN],inbuff[MLEN];
//char PWD_buffer[_MAX_PATH];
struct sockaddr_in servaddr;
FILE *fp;
int numbytes;
char buf[2048];
if (argc != 2)
fprintf(stderr, "error");
if ( (sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0)
fprintf(stderr, "socket error");
memset(&servaddr, 0, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_port = htons(PORT);
if (connect(sockfd, (struct sockaddr *) &servaddr, sizeof(servaddr)) < 0)
fprintf(stderr, "connect error");
if ( (fp = fopen("/home/na/nall9047/write.txt", "w")) == NULL){
perror("fopen");
exit(1);
}
printf("Still NO PROBLEM!\n");
//Receive file from server
while(1){
numbytes = read(sockfd, buf, sizeof(buf));
printf("read %d bytes, ", numbytes);
if(numbytes == 0){
printf("\n");
break;
}
numbytes = fwrite(buf, sizeof(char), numbytes, fp);
printf("fwrite %d bytes\n", numbytes);
}
fclose(fp);
close(sockfd);
return 0;
}
SERVERFILE.C
#include stdio.h
#include fcntl.h
#include stdlib.h
#include time.h
#include string.h
#include netinet/in.h
#include errno.h
#include sys/types.h
#include sys/socket.h
#includ estdarg.h
#define PORT 5678
#define MLEN 1000
int main(int argc, char *argv [])
{
int listenfd, connfd;
int number, message, numbytes;
int h, i, j, alen;
int nread;
struct sockaddr_in servaddr;
struct sockaddr_in cliaddr;
FILE *in_file, *out_file, *fp;
char buf[4096];
listenfd = socket(AF_INET, SOCK_STREAM, 0);
if (listenfd < 0)
fprintf(stderr,"listen error") ;
memset(&servaddr, 0, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
servaddr.sin_port = htons(PORT);
if (bind(listenfd, (struct sockaddr *) &servaddr, sizeof(servaddr)) < 0)
fprintf(stderr,"bind error") ;
alen = sizeof(struct sockaddr);
connfd = accept(listenfd, (struct sockaddr *) &cliaddr, &alen);
if (connfd < 0)
fprintf(stderr,"error connecting") ;
printf("accept one client from %s!\n", inet_ntoa(cliaddr.sin_addr));
fp = fopen ("/home/na/nall9047/read.txt", "r"); // open file stored in server
if (fp == NULL) {
printf("\nfile NOT exist");
}
//Sending file
while(!feof(fp)){
numbytes = fread(buf, sizeof(char), sizeof(buf), fp);
printf("fread %d bytes, ", numbytes);
numbytes = write(connfd, buf, numbytes);
printf("Sending %d bytes\n",numbytes);
}
fclose (fp);
close(listenfd);
close(connfd);
return 0;
}
答案 0 :(得分:1)
我看到了几个问题:
您正在读取()和写入()套接字句柄。适用于某些操作系统,但不适用于其他操作系统。如果您完全关心可移植性(或者如果您的操作系统是读/写中断之一),您将需要recv()和send()。
你是关闭()没有先关闭()的套接字句柄。这很可能导致发送的最后一个字节被丢弃。
fread是一个函数,而不是一个变量。你可能希望你的循环看起来像
while(!feof(fp)){
更新:您在哪里设置要连接的地址?
答案 1 :(得分:0)
来自其他任何地方的公寓,fread是函数的名称,并且计算为非零函数指针值。所以:
while(fread < 0){
永远不会是真的。