日期:2014-05-16  浏览次数:20680 次

unix中简单的C/S文件通信(二)
我把"unix中简单的C/S文件通信"中的代码改进了下,服务器端给客户端发完文件,即客户端接收完文件后再给服务器端发文件,但程序似乎卡在了客户端发送文件那儿,求各位高手给看看,能给一些改进的提示也好,谢谢各位高手了,改进后原代码如下:
  newserver:
 #include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <fcntl.h>



#define TRUE 1 /////////////
#define DataNum 126 //////////// 有用的126字节
#define BUFSIZE 128 ///////////// 每次发送128字节
#define PERM 0644 /* 创建文件的默认属性*/
/*发的时候是128,*/
main ()
{
  int sock,length,clilen;
  struct sockaddr_in server,client;
  int msgsock;
  char newbuf[BUFSIZE];
  int newoutfile;
  ssize_t newnread;
  int j=0;
  int newrealn;
  char newcharnum;

  /******************************建立Socket连接*********************************/
  sock=socket(AF_INET,SOCK_STREAM,0); //申请socket资源  
  if (sock<0)
  {
  perror("opening stream socket");
  exit(1);
  }

  server.sin_family=AF_INET;
  server.sin_addr.s_addr=INADDR_ANY; /*必然的,这里指的是Internet协议*/
  server.sin_port=0;/*这里,是让系统自动分配一个端口号,在1024到5000之间65535个端口 ,端口设为0,系统自动分配 */  
  if (bind(sock,(struct sockaddr *)&server,sizeof server)<0) /*将IP地址和端口号绑到sock上 */
  {
  perror("binding stream socket");
  exit(1);
  }

  length=sizeof server;
  if (getsockname(sock,(struct sockaddr *)&server,&length)<0) /*获得指定socket的本地地址,成功返回0,错误返回-1*/
  {
  perror("getting socket name");
  exit(1);
  }
  printf("Socket port # %d\n",ntohs(server.sin_port)); /* 打印出系统分的端口号,给client用*/

  listen(sock,5); /*5个连接请求排队等待,一般5个 Pause Here 等待client连接*/

  /****************现在是等待客户来连接,如果来客户了,那就建好了socket,就可以当文件使用**********/
  clilen=sizeof client;  
  msgsock=accept(sock,(struct sockaddr *)&client,(int *) &clilen);/*创建一个新的与sock相同的socket并返回其值*/
  if (msgsock==-1) /*非并发处理,反复型*/
  perror("accept");
  else  
  { /**********这里开始进行文件处理,一直到最后************/
  int infile;
  ssize_t nread;
  char buf[BUFSIZE]; // 发送/接收缓冲区
  int rval;
  int i = 0; /*计数器: 数据块编号*/

  if((infile=open("send.txt",O_RDONLY))==-1) //只读方式打开test.txt ,iffile文件指针
  {
  printf("send.txt NOT Found, or program stopped!\n");
  exit(1);
  }

  memset(buf,0,sizeof buf);/*缓冲区清零*/
  while((nread = read(infile,buf,DataNum)) > 0) /*将文件读到缓冲区, 每次读126字节 */
  {
  //printf("从文件中读了大小为 %d 的数据\n",nread);
  buf[DataNum]=nread; /* 把实际信息多少的数字放在发送缓冲区的最后第二字节*/
  i++;
  buf[DataNum+1] = (i%10)+48;  
  if(write(msgsock,buf,BUFSIZE) == -1)/*将缓冲区的内容写到msgsock*/
  printf("Error Writing sock\n");
  else
  printf("Sending the %d th pack to sock, size: %d \n",i,nread);

  memset(buf,0,sizeof buf); /*缓冲区清零*/

  if((rval = read(msgsock,buf,BUFSIZE)) &