php中使用sftp教程_PHP教程

编辑Tag赚U币
教程Tag:暂无Tag,欢迎添加,赚取U币!

推荐:php计算一个文件大小的方法
这篇文章主要介绍了php计算一个文件大小的方法,涉及php操作文件的技巧,具有一定参考借鉴价值,需要的朋友可以参考下 本文实例讲述了php计算一个文件大小的方法。分享给大家供大家参考。具体如下: ? 希望本文所述对大家的php程序设计有所帮助。

这篇文章主要介绍了php中使用sftp教程,本文讲解了ftp 协议简介、ssh协议、sftp 协议等知识,并给出了FTP和SFTP操作类实现代码,需要的朋友可以参考下

  1. <?php  
  2.   
  3.   
  4. /** 
  5. php 中的sftp 使用教程  
  6. Telnet、FTP、SSH、SFTP、SSL  
  7. (一) ftp 协议简介  
  8.   
  9.     FTP(File Transfer Protocol,文件传输协议)是互联网上常用的协议之一,人们用FTP实现互连网上的文件传输。 
  10. 如同其他的很多通讯协议,FTP通讯协议也采用客户机 / 服务器(Client / Server )架构。用户可以通过各种不同的FTP客户端程序, 
  11. 借助FTP协议,来连接FTP服务器,以上传或者下载文件FTP的命令传输和数据传输是通过不同的端口进行传输的 
  12. FTP是TCP/IP的一种具体应用,它工作在OSI模型的第七层,TCP模型的第四层上,即应用层,使用TCP传输而不是UDP, 
  13. 这样FTP客户在和服 务器建立连接前就要经过一个被广为熟知的"三次握手"的过程,它带来的意义在于客户与服务器之间的连接是可靠的, 
  14. 而且是面向连接,为数据的传输提供了可靠 的保证。 
  15.   
  16. (二)ssh协议  
  17.   
  18.     ssh 的全称为 SecureShell  ,可以报所有的传输数据惊醒加密,这样'中间人'就不能获得我们传输的数据 
  19. 同事,传输的数据是经过压缩的,可以加快传输的速度.ssh有很多功能,可以替代telnet 也可也为ftppop ,提供一个安全的通道  
  20.   
  21.   SSH协议框架中最主要的部分是三个协议: 
  22.    
  23. * 传输层协议(The Transport Layer Protocol)提供服务器认证,数据机密性,信息完整性 等的支持; 
  24. * 用户认证协议(The User Authentication Protocol) 则为服务器提供客户端的身份鉴别; 
  25. * 连接协议(The Connection Protocol) 将加密的信息隧道复用成若干个逻辑通道,提供给更高层的应用协议使用;  
  26.  各种高层应用协议可以相对地独立于SSH基本体系之外,并依靠这个基本框架,通过连接协议使用SSH的安全机制。 
  27.    
  28.  (三)sftp 协议  
  29.   使用SSH协议进行FTP传输的协议叫SFTP(安全文件传输)Sftp和Ftp都是文件传输协议。区别:sftp是ssh内含的协议(ssh是加密的telnet协议), 
  30.     只要sshd服务器启动了,它就可用,而且sftp安全性较高,它本身不需要ftp服务器启动。 sftp = ssh + ftp(安全文件传输协议)。由于ftp是明文传输的, 
  31.     没有安全性,而sftp基于ssh,传输内容是加密过的,较为安全。目前网络不太安全,以前用telnet的都改用ssh2(SSH1已被破解)。sftp这个工具和ftp用 
  32.     法一样。但是它的传输文件是通过ssl加密了的,即使被截获了也无法破解。而且sftp相比ftp功能要多一些,多了一些文件属性的设置 
  33.   
  34.       
  35.     */ 
  36.       
  37.   
  38.   
  39.           
  40. // 注意这里只是为了介绍ftp ,并没有做验证 ;       
  41. class ftp{ 
  42.       
  43.     // 初始配置为NULL 
  44.     private $config =NULL ; 
  45.     // 连接为NULL  
  46.     private $conn = NULL; 
  47.       
  48.     public function init($config){ 
  49.      $this->config = $config;     
  50.     } 
  51.       
  52.     // ftp 连接  
  53.     public function connect(){ 
  54.         return $this->conn = ftp_connect($this->config['host'],$this->config['port']));  
  55.     } 
  56.       
  57.       
  58.     // 传输数据 传输层协议,获得数据 true or false  
  59.   public function download($remote$local,$mode = 'auto'){ 
  60.       return $result = @ftp_get($this->conn, $localpath$remotepath$mode); 
  61.   } 
  62.     
  63.   // 传输数据 传输层协议,上传数据 true or false  
  64.   public function upload($remote$local,$mode = 'auto'){ 
  65.       return $result = @ftp_put($this->conn, $localpath$remotepath$mode); 
  66.   } 
  67.     
  68.     
  69.      // 删除文件  
  70.     public function remove($remote){ 
  71.      return $result = @ftp_delete($this->conn_id, $file); 
  72.     } 
  73.     
  74.       
  75. }        
  76.   
  77.   
  78.   
  79. // 使用  
  80. $config = array
  81.             'hostname' => 'localhost'
  82.       'username' => 'root'
  83.       'password' => 'root'
  84.       'port' => 21 
  85.   
  86. ) ; 
  87.    
  88. $ftp = new Ftp(); 
  89. $ftp->connect($config); 
  90. $ftp->upload('ftp_err.log','ftp_upload.log'); 
  91. $ftp->download('ftp_upload.log','ftp_download.log'); 
  92.   
  93.   
  94.   
  95. /*根据上面的三个协议写出基于ssh 的ftp 类 
  96. 我们知道进行身份认证的方式有两种:公钥;密码 ; 
  97. (1) 使用密码登陆 
  98. (2) 免密码登陆也就是使用公钥登陆  
  99.   
  100. */ 
  101.   
  102. class sftp{ 
  103.       
  104.       
  105.     // 初始配置为NULL 
  106.     private $config =NULL ; 
  107.     // 连接为NULL  
  108.     private $conn = NULL; 
  109.   
  110.       
  111.     // 是否使用秘钥登陆  
  112.      private $use_pubkey_file= false; 
  113.       
  114.     // 初始化 
  115.     public function init($config){ 
  116.         $this->config = $config ;  
  117.     } 
  118.       
  119.       
  120.     // 连接ssh ,连接有两种方式(1) 使用密码 
  121.     // (2) 使用秘钥  
  122.     public function connect(){ 
  123.           
  124.         $methods['hostkey'] = $use_pubkey_file ? 'ssh-rsa' : [] ;  
  125.         $con = ssh2_connect($this->config['host'], $this->config['port'], $methods); 
  126.         //(1) 使用秘钥的时候  
  127.         if($use_pubkey_file){ 
  128.         // 用户认证协议 
  129.              $rc = ssh2_auth_pubkey_file( 
  130.                 $conn
  131.                 $this->config['user'], 
  132.                 $this->config['pubkey_file'], 
  133.                 $this->config['privkey_file'], 
  134.                 $this->config['passphrase'])  
  135.             ); 
  136.         //(2) 使用登陆用户名字和登陆密码 
  137.         }else
  138.             $rc = ssh2_auth_password( $conn$this->conf_['user'],$this->conf_['passwd']); 
  139.         
  140.         } 
  141.           
  142.         return $rc ;  
  143.     } 
  144.       
  145.       
  146.     // 传输数据 传输层协议,获得数据 
  147.       public function download($remote$local){ 
  148.             
  149.           return ssh2_scp_recv($this->conn_, $remote$local); 
  150.       } 
  151.         
  152.      //传输数据 传输层协议,写入ftp服务器数据 
  153.      public function upload($remote$local,$file_mode=0664){ 
  154.           return ssh2_scp_send($this->conn_, $local$remote$file_mode); 
  155.             
  156.      } 
  157.        
  158.      // 删除文件  
  159.       public function remove($remote){ 
  160.             $sftp = ssh2_sftp($this->conn_); 
  161.             $rc  = false; 
  162.   
  163.     if (is_dir("ssh2.sftp://{$sftp}/{$remote}")) { 
  164.             $rc = false ; 
  165.               
  166.             // ssh 删除文件夹 
  167.       $rc = ssh2_sftp_rmdir($sftp$remote); 
  168.             } else { 
  169.           // 删除文件 
  170.                 $rc = ssh2_sftp_unlink($sftp$remote); 
  171.             } 
  172.             return $rc
  173.               
  174.         } 
  175.            
  176.    
  177.    
  178.       
  179.   
  180.   
  181. $config = [ 
  182.   "host"     => "192.168.1.1 ",   // ftp地址 
  183.   "user"     => "***",  
  184.   "port"     => "22"
  185.   "pubkey_path" => "/root/.ssh/id_rsa.pub",  // 公钥的存储地址 
  186.   "privkey_path" => "/root/.ssh/id_rsa",     // 私钥的存储地址 
  187. ]; 
  188.   
  189. $handle = new SftpAccess(); 
  190. $handle->init($config); 
  191. $rc = $handle->connect(); 
  192. $handle->getData(remote, $local); 
  193.           
  194.   

分享:smarty模板引擎之内建函数用法
这篇文章主要介绍了smarty模板引擎之内建函数用法,实例分析了smarty中foreach函数、if...else...、if...elseif...elseif...else...等内建函数的使用方法,具有一定参考借鉴价值,需要的朋友可以参考下 本文实例讲述了smarty内建函数的使用方法。分享给大家供大家参考。具

来源:模板无忧//所属分类:PHP教程/更新时间:2015-04-01
相关PHP教程