快捷搜索:   nginx

linux下用TCP/IP编程实现远程文件传输

在TCP/IP网络结构中,为了保证网络安全,网络人员往往需要在路由器上添加防火墙,禁止非法用户用ftp等安全危害较大的TCP/IP协议访问主机。而有时系统维护人员需要用ftp将一些文件从中心机房主机传到前端网点主机上,比如应用程序的替换升级。如果每次传输文件时都要打开防火墙,未免显得有些繁琐,要是在自己的应用程序中增加一个专门的文件传输模块,那将是十分愉快的事情。

  UNIX网络程序设计一般都采用套接字(socket)系统调用。针对目前十分流行的客户/服务器模式,其程序编写步骤如下:

  1.Socket系统调用

  为了进行网络I/O,服务器和客户机两端的UNIX进程要做的第一件事是调用socket()系统调用,建立软插座,指明合适的通讯协议。格式为:

  #include >sys/types.h>

  #include >sys/socket.h>

  int socket(int family,int type,int protocol)

  其中:(1)family指明套节字族,其值包括:

  AF_UNIX

  (UNIX内部协议族)

  AF_INET

  (Iternet协议)

  AF_NS (XeroxNs协议,TCP/IP编程取该值)

  AF_IMPLINK

  (IMP链接层)

  (2)type 指明套接字类型,取值有:

  SOCK_STREAM

  (流套接字)

  SOCK_DGRAM

  (数据报套接字)

  SOCK_RAW

  (原始套接字)

  SOCK_SEQPACKET

  (定序分组套接字)

  一般情况下,前两个参数的组合就可以决定所使用的协议,这时第三个参数被置为0,如果第一个参数为AF_INET,第二个参数选SOCK_STREAM,则使用的协议为TCP;第二个参数选SOCK_DGRAM,则使用的协议为UDP;当第二个参数选SOCK_RAW时,使用的协议为IP。值得指出的是并不是所有的族和类型的组合都是合法的,具体请查阅相关资料。该系统调用若成功则返回一个类似文件描述符,成为套节字描述字,可以像文件描述符那样用read和write对其进行I/O操作。当一个进程使用完该软插座时,需用close()关闭(具体见后面内容)。

  2.服务器端Bind系统调用

  软插座创建时并没有与任何地址相关联,必须用bind()系统调用为其建立地址联系。其格式为:

  #include

  #include

  int bind(int socketfd,struct sockaddr_in *localaddr,sizeof(localaddr));

  其中:(1)第一个参数socketfd是前步socket()系统调用返回的套节字描述符。

  (2)第二个参数被捆向本地地址的一种结构,该结构在sys/netinet/in.h中定义:

  struct sockaddr_in{

  short sin_family;/*socket()系统调用的协议族如AF_INET*/

  u_short sin_port;/*网络字节次序形式的端口号码*/

  struct in_addr sin_addr;/*网络字节次序形式的网络地址*/

  char sin_zero[8];

  }

  一台机器上的每个网络程序使用一个各自独立的端口号码,例如:telnet程序使用端口号23,而ftp文件传输程序使用端口号21。我们在设计应用程序时,端口号码可以由getservbyname()函数从/etc/services库文件中获取,也可以由htons (int portnum)函数将任意正整数转换为网络字节次序形式来得到,有些版本的UNIX操作系统则规定1024以下的端口号码只可被超级用户使用,普通用户程序使用的端口号码只限于1025到32767之间。网络地址可以由gethostbyname(char*hostname)函数得到(该函数和getservbyname()一样都以网络字节次序形式返回所有在他们结构中的数据),参数hostname为/etc/hosts文件中某一网络地址所对应的机器名。该函数返回一个类型为hostent的结构指针,hostent结构在netdb.h中定义:
顶(0)
踩(0)

您可能还会对下面的文章感兴趣:

最新评论