[代码]c代码server部分
viewsource
print?
003 | ==================================================================== |
005 | #include<netinet/in.h>//forsockaddr_in
|
006 | #include<sys/types.h>//forsocket
|
007 | #include<sys/socket.h>//forsocket
|
008 | #include<stdio.h>//forprintf
|
009 | #include<stdlib.h>//forexit
|
010 | #include<string.h>//forbzero
|
017 | #defineHELLO_WORLD_SERVER_PORT6666
|
018 | #defineLENGTH_OF_LISTEN_QUEUE20
|
019 | #defineBUFFER_SIZE1024
|
020 | #defineFILE_NAME_MAX_SIZE512
|
022 | int main( int argc, char **argv)
|
024 | //设置一个socket地址结构server_addr,代表服务器internet地址,端口
|
025 | struct
sockaddr_inserver_addr; |
026 | bzero(&server_addr, sizeof (server_addr)); //把一段内存区的内容全部设置为0 |
027 | server_addr.sin_family=AF_INET; |
028 | server_addr.sin_addr.s_addr=htons(INADDR_ANY); |
029 | server_addr.sin_port=htons(HELLO_WORLD_SERVER_PORT); |
031 | //创建用于internet的流协议(TCP)socket,用server_socket代表服务器socket |
032 | int
server_socket=socket(PF_INET,SOCK_STREAM,0); |
035 | printf ( "CreateSocketFailed!" ); |
040 | setsockopt(server_socket,SOL_SOCKET,SO_REUSEADDR,&opt, sizeof (opt)); |
043 | //把socket和socket地址结构联系起来 |
044 | if (bind(server_socket,( struct
sockaddr*)&server_addr, sizeof (server_addr))) |
046 | printf ( "ServerBindPort:%dFailed!" ,HELLO_WORLD_SERVER_PORT); |
051 | if
(listen(server_socket,LENGTH_OF_LISTEN_QUEUE))
|
053 | printf ( "ServerListenFailed!" ); |
058 | //定义客户端的socket地址结构client_addr |
059 | struct
sockaddr_inclient_addr; |
060 | socklen_tlength=
sizeof (client_addr); |
062 | //接受一个到server_socket代表的socket的一个连接 |
063 | //如果没有连接请求,就等待到有连接请求--这是accept函数的特性 |
064 | //accept函数返回一个新的socket,这个socket(new_server_socket)用于同连接到的客户的通信 |
065 | //new_server_socket代表了服务器和客户端之间的一个通信通道 |
066 | //accept函数把连接到的客户端信息填写到客户端的socket地址结构client_addr中 |
067 | int
new_server_socket=accept(server_socket,( struct
sockaddr*)&client_addr,&length); |
068 | if
(new_server_socket<0) |
070 | printf ( "ServerAcceptFailed!\n" ); |
074 | char
buffer[BUFFER_SIZE]; |
075 | bzero(buffer,BUFFER_SIZE); |
076 | length=recv(new_server_socket,buffer,BUFFER_SIZE,0); |
079 | printf ( "ServerRecieveDataFailed!\n" ); |
082 | char
file_name[FILE_NAME_MAX_SIZE+1]; |
083 | bzero(file_name,FILE_NAME_MAX_SIZE+1); |
084 | strncpy (file_name,buffer, strlen (buffer)>FILE_NAME_MAX_SIZE?FILE_NAME_MAX_SIZE: strlen (buffer)); |
085 | //intfp=open(file_name,O_RDONLY); |
087 | printf ( "%s\n" ,file_name); |
088 | FILE
*fp= fopen (file_name, "r" ); |
091 | printf ( "File:\t%sNotFound\n" ,file_name); |
095 | bzero(buffer,BUFFER_SIZE); |
096 | int
file_block_length=0; |
097 | //while((file_block_length=read(fp,buffer,BUFFER_SIZE))>0)
|
098 | while ((file_block_length=
fread (buffer, sizeof ( char ),BUFFER_SIZE,fp))>0) |
100 | printf ( "file_block_length=%d\n" ,file_block_length); |
101 | //发送buffer中的字符串到new_server_socket,实际是给客户端 |
102 | if (send(new_server_socket,buffer,file_block_length,0)<0) |
104 | printf ( "SendFile:\t%sFailed\n" ,file_name); |
107 | bzero(buffer,BUFFER_SIZE); |
111 | printf ( "File:\t%sTransferFinished\n" ,file_name); |
114 | close(new_server_socket); |
[代码]c代码client部分
viewsource
print?
003 | #include<netinet/in.h>//forsockaddr_in
|
004 | #include<sys/types.h>//forsocket
|
005 | #include<sys/socket.h>//forsocket
|
006 | #include<stdio.h>//forprintf
|
007 | #include<stdlib.h>//forexit
|
008 | #include<string.h>//forbzero
|
016 | #defineHELLO_WORLD_SERVER_PORT6666
|
017 | #defineBUFFER_SIZE1024
|
018 | #defineFILE_NAME_MAX_SIZE512
|
020 | int main( int argc, char **argv)
|
024 | printf ( "Usage:./%sServerIPAddress\n" ,argv[0]); |
028 | //设置一个socket地址结构client_addr,代表客户机internet地址,端口
|
029 | struct
sockaddr_inclient_addr; |
030 | bzero(&client_addr, sizeof (client_addr)); //把一段内存区的内容全部设置为0 |
031 | client_addr.sin_family=AF_INET; //internet协议族 |
032 | client_addr.sin_addr.s_addr=htons(INADDR_ANY); //INADDR_ANY表示自动获取本机地址 |
033 | client_addr.sin_port=htons(0); //0表示让系统自动分配一个空闲端口 |
034 | //创建用于internet的流协议(TCP)socket,用client_socket代表客户机socket |
035 | int
client_socket=socket(AF_INET,SOCK_STREAM,0); |
038 | printf ( "CreateSocketFailed!\n" ); |
041 | //把客户机的socket和客户机的socket地址结构联系起来 |
042 | if (bind(client_socket,( struct
sockaddr*)&client_addr, sizeof (client_addr))) |
044 | printf ( "ClientBindPortFailed!\n" ); |
048 | //设置一个socket地址结构server_addr,代表服务器的internet地址,端口
|
049 | struct
sockaddr_inserver_addr; |
050 | bzero(&server_addr, sizeof (server_addr)); |
051 | server_addr.sin_family=AF_INET; |
052 | if (inet_aton(argv[1],&server_addr.sin_addr)==0)
//服务器的IP地址来自程序的参数 |
054 | printf ( "ServerIPAddressError!\n" ); |
057 | server_addr.sin_port=htons(HELLO_WORLD_SERVER_PORT); |
058 | socklen_tserver_addr_length=
sizeof (server_addr); |
059 | //向服务器发起连接,连接成功后client_socket代表了客户机和服务器的一个socket连接 |
060 | if (connect(client_socket,( struct
sockaddr*)&server_addr,server_addr_length)<0) |
062 | printf ( "CanNotConnectTo%s!\n" ,argv[1]); |
066 | char
file_name[FILE_NAME_MAX_SIZE+1]; |
067 | bzero(file_name,FILE_NAME_MAX_SIZE+1); |
068 | printf ( "PleaseInputFileNameOnServer:\t" ); |
069 | scanf ( "%s" ,file_name); |
071 | char
buffer[BUFFER_SIZE]; |
072 | bzero(buffer,BUFFER_SIZE); |
073 | strncpy (buffer,file_name, strlen (file_name)>BUFFER_SIZE?BUFFER_SIZE: strlen (file_name)); |
075 | send(client_socket,buffer,BUFFER_SIZE,0); |
077 | //intfp=open(file_name,O_WRONLY|O_CREAT); |
079 | FILE
*fp= fopen (file_name, "w" ); |
082 | printf ( "File:\t%sCanNotOpenToWrite\n" ,file_name); |
087 | bzero(buffer,BUFFER_SIZE); |
089 | while (length=recv(client_socket,buffer,BUFFER_SIZE,0))
|
093 | printf ( "RecieveDataFromServer%sFailed!\n" ,argv[1]); |
096 | //intwrite_length=write(fp,buffer,length); |
097 | int
write_length= fwrite (buffer, sizeof ( char ),length,fp); |
098 | if
(write_length<length) |
100 | printf ( "File:\t%sWriteFailed\n" ,file_name); |
103 | bzero(buffer,BUFFER_SIZE); |
105 | printf ( "RecieveFile:\t%sFromServer[%s]Finished\n" ,file_name,argv[1]); |
[代码]open等,fopen等说明
viewsource
print?
01 | 某些注释部分,open,read,write被 fopen , fread , fwrite 替换。 |
04 | fopen , fclose ,
fread , fwrite , fgetc ,
fgets , fputc , fputs ,
freopen , fseek , ftell ,
rewind 等 |
06 | 缓冲文件系统的特点是:在内存开辟一个“缓冲区”,为程序中的每一个文件使用,当执行读文件的操作时, |
07 | 从磁盘文件将数据先读入内存“缓冲区”,装满后再从内存“缓冲区”依此读入接收的变量。执行写文件的
|
08 | 操作时,先将数据写入内存“缓冲区”,待内存“缓冲区”装满后再写入文件。由此可以看出,内存 |
09 | “缓冲区”的大小,影响着实际操作外存的次数,内存“缓冲区”越大,则操作外存的次数就少, |
10 | 执行速度就快、效率高。一般来说,文件“缓冲区”的大小随机器而定。
|
12 | open,close,read,write, getc , getchar ,
putc , putchar
等 |
14 | 非缓冲文件系统是借助文件结构体指针来对文件进行管理,通过文件指针来对文件进行访问,既可以读写字符、 |
15 | 字符串、格式化数据,也可以读写二进制数据。非缓冲文件系统依赖于操作系统,通过操作系统的功能对
|
16 | 文件进行读写,是系统级的输入输出,它不设文件结构体指针,只能读写二进制文件,但效率高、速度快, |
17 | 由于ANSI标准不再包括非缓冲文件系统,因此建议大家最好不要选择它。
|
22 | open等返回一个文件描述符(用户程序区的), |
27 | fopen 等是在open等的基础上扩充而来的,在大多数情况下,用 fopen 等。 |
29 | open是系统调用返回的是文件句柄,文件的句柄是文件在文件描述符表里的索引,
|
30 | fopen 是C的库函数,返回的是一个指向文件结构的指针。 |
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理