http://www.oschina.net/code/snippet_97047_675
[1].[代码] c代码 server部分 跳至 [1] [2] [3]
003 | ==================================================================== |
005 | #include <netinet/in.h> // for sockaddr_in |
006 | #include <sys/types.h> // for socket |
007 | #include <sys/socket.h> // for socket |
008 | #include <stdio.h> // for printf |
009 | #include <stdlib.h> // for exit |
010 | #include <string.h> // for bzero |
017 | #define HELLO_WORLD_SERVER_PORT 6666 |
018 | #define LENGTH_OF_LISTEN_QUEUE 20 |
019 | #define BUFFER_SIZE 1024 |
020 | #define FILE_NAME_MAX_SIZE 512 |
022 | int main( int argc, char **argv) |
025 | struct sockaddr_in server_addr; |
026 | bzero(&server_addr, sizeof (server_addr)); |
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); |
032 | int server_socket = socket(PF_INET,SOCK_STREAM,0); |
033 | if ( server_socket < 0) |
035 | printf ( "Create Socket Failed!" ); |
040 | setsockopt(server_socket,SOL_SOCKET,SO_REUSEADDR,&opt, sizeof (opt)); |
044 | if ( bind(server_socket,( struct sockaddr*)&server_addr, sizeof (server_addr))) |
046 | printf ( "Server Bind Port : %d Failed!" , HELLO_WORLD_SERVER_PORT); |
051 | if ( listen(server_socket, LENGTH_OF_LISTEN_QUEUE) ) |
053 | printf ( "Server Listen Failed!" ); |
059 | struct sockaddr_in client_addr; |
060 | socklen_t length = sizeof (client_addr); |
067 | int new_server_socket = accept(server_socket,( struct sockaddr*)&client_addr,&length); |
068 | if ( new_server_socket < 0) |
070 | printf ( "Server Accept Failed!\n" ); |
074 | char buffer[BUFFER_SIZE]; |
075 | bzero(buffer, BUFFER_SIZE); |
076 | length = recv(new_server_socket,buffer,BUFFER_SIZE,0); |
079 | printf ( "Server Recieve Data Failed!\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)); |
087 | printf ( "%s\n" ,file_name); |
088 | FILE * fp = fopen (file_name, "r" ); |
091 | printf ( "File:\t%s Not Found\n" , file_name); |
095 | bzero(buffer, BUFFER_SIZE); |
096 | int file_block_length = 0; |
098 | while ( (file_block_length = fread (buffer, sizeof ( char ),BUFFER_SIZE,fp))>0) |
100 | printf ( "file_block_length = %d\n" ,file_block_length); |
102 | if (send(new_server_socket,buffer,file_block_length,0)<0) |
104 | printf ( "Send File:\t%s Failed\n" , file_name); |
107 | bzero(buffer, BUFFER_SIZE); |
111 | printf ( "File:\t%s Transfer Finished\n" ,file_name); |
114 | close(new_server_socket); |
117 | close(server_socket); |
[2].[代码] c代码 client部分 跳至 [1] [2] [3]
003 | #include <netinet/in.h> // for sockaddr_in |
004 | #include <sys/types.h> // for socket |
005 | #include <sys/socket.h> // for socket |
006 | #include <stdio.h> // for printf |
007 | #include <stdlib.h> // for exit |
008 | #include <string.h> // for bzero |
016 | #define HELLO_WORLD_SERVER_PORT 6666 |
017 | #define BUFFER_SIZE 1024 |
018 | #define FILE_NAME_MAX_SIZE 512 |
020 | int main( int argc, char **argv) |
024 | printf ( "Usage: ./%s ServerIPAddress\n" ,argv[0]); |
029 | struct sockaddr_in client_addr; |
030 | bzero(&client_addr, sizeof (client_addr)); |
031 | client_addr.sin_family = AF_INET; |
032 | client_addr.sin_addr.s_addr = htons(INADDR_ANY); |
033 | client_addr.sin_port = htons(0); |
035 | int client_socket = socket(AF_INET,SOCK_STREAM,0); |
036 | if ( client_socket < 0) |
038 | printf ( "Create Socket Failed!\n" ); |
042 | if ( bind(client_socket,( struct sockaddr*)&client_addr, sizeof (client_addr))) |
044 | printf ( "Client Bind Port Failed!\n" ); |
049 | struct sockaddr_in server_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) |
054 | printf ( "Server IP Address Error!\n" ); |
057 | server_addr.sin_port = htons(HELLO_WORLD_SERVER_PORT); |
058 | socklen_t server_addr_length = sizeof (server_addr); |
060 | if (connect(client_socket,( struct sockaddr*)&server_addr, server_addr_length) < 0) |
062 | printf ( "Can Not Connect To %s!\n" ,argv[1]); |
066 | char file_name[FILE_NAME_MAX_SIZE+1]; |
067 | bzero(file_name, FILE_NAME_MAX_SIZE+1); |
068 | printf ( "Please Input File Name On Server:\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); |
079 | FILE * fp = fopen (file_name, "w" ); |
082 | printf ( "File:\t%s Can Not Open To Write\n" , file_name); |
087 | bzero(buffer,BUFFER_SIZE); |
089 | while ( length = recv(client_socket,buffer,BUFFER_SIZE,0)) |
093 | printf ( "Recieve Data From Server %s Failed!\n" , argv[1]); |
097 | int write_length = fwrite (buffer, sizeof ( char ),length,fp); |
098 | if (write_length<length) |
100 | printf ( "File:\t%s Write Failed\n" , file_name); |
103 | bzero(buffer,BUFFER_SIZE); |
105 | printf ( "Recieve File:\t %s From Server[%s] Finished\n" ,file_name, argv[1]); |
109 | close(client_socket); |
[3].[代码] open等,fopen等说明 跳至 [1] [2] [3]
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的库函数,返回的是一个指向文件结构的指针。 |