搜尋
首頁php教程php手册php 中的sftp 使用教程

php 中的sftp 使用教程

<!--?php  


/**
php 中的sftp 使用教程 
Telnet、FTP、SSH、SFTP、SSL  
(一) ftp 协议简介 

	FTP(File Transfer Protocol,文件传输协议)是互联网上常用的协议之一,人们用FTP实现互连网上的文件传输。
如同其他的很多通讯协议,FTP通讯协议也采用客户机 / 服务器(Client / Server )架构。用户可以通过各种不同的FTP客户端程序,
借助FTP协议,来连接FTP服务器,以上传或者下载文件FTP的命令传输和数据传输是通过不同的端口进行传输的
FTP是TCP/IP的一种具体应用,它工作在OSI模型的第七层,TCP模型的第四层上,即应用层,使用TCP传输而不是UDP,
这样FTP客户在和服 务器建立连接前就要经过一个被广为熟知的三次握手的过程,它带来的意义在于客户与服务器之间的连接是可靠的,
而且是面向连接,为数据的传输提供了可靠 的保证。

(二)ssh协议 

	ssh 的全称为 SecureShell   ,可以报所有的传输数据惊醒加密,这样&#39;中间人&#39;就不能获得我们传输的数据
同事,传输的数据是经过压缩的,可以加快传输的速度.ssh有很多功能,可以替代telnet 也可也为ftppop ,提供一个安全的通道 

   SSH协议框架中最主要的部分是三个协议:
 
* 传输层协议(The Transport Layer Protocol)提供服务器认证,数据机密性,信息完整性 等的支持;
* 用户认证协议(The User Authentication Protocol) 则为服务器提供客户端的身份鉴别;
* 连接协议(The Connection Protocol) 将加密的信息隧道复用成若干个逻辑通道,提供给更高层的应用协议使用; 
  各种高层应用协议可以相对地独立于SSH基本体系之外,并依靠这个基本框架,通过连接协议使用SSH的安全机制。
  
 (三)sftp 协议 
    使用SSH协议进行FTP传输的协议叫SFTP(安全文件传输)Sftp和Ftp都是文件传输协议。区别:sftp是ssh内含的协议(ssh是加密的telnet协议),
	只要sshd服务器启动了,它就可用,而且sftp安全性较高,它本身不需要ftp服务器启动。 sftp = ssh + ftp(安全文件传输协议)。由于ftp是明文传输的,
	没有安全性,而sftp基于ssh,传输内容是加密过的,较为安全。目前网络不太安全,以前用telnet的都改用ssh2(SSH1已被破解)。sftp这个工具和ftp用
	法一样。但是它的传输文件是通过ssl加密了的,即使被截获了也无法破解。而且sftp相比ftp功能要多一些,多了一些文件属性的设置

	
	*/
	


		
// 注意这里只是为了介绍ftp ,并没有做验证 ; 		
class ftp{
	
	// 初始配置为NULL
	private  $config =NULL ;
	// 连接为NULL 
	private  $conn = NULL;
	
	public function init($config){
	  $this--->config = $config; 	
	}
	
	// ftp 连接 
	public function connect(){
		return  $this->conn = ftp_connect($this->config[&#39;host&#39;],$this->config[&#39;port&#39;])); 
	}
	
	
	// 传输数据  传输层协议,获得数据 true or false 
   public function download($remote, $local,$mode = &#39;auto&#39;){
	   return $result = @ftp_get($this->conn, $localpath, $remotepath, $mode);
   }
   
   // 传输数据  传输层协议,上传数据 true or false 
   public function upload($remote, $local,$mode = &#39;auto&#39;){
	   return $result = @ftp_put($this->conn, $localpath, $remotepath, $mode);
   }
   
   
  	  // 删除文件  
	public function remove($remote){
	  return  $result = @ftp_delete($this->conn_id, $file);
	}
   
	
}		



// 使用 
$config = array(
			&#39;hostname&#39; => &#39;localhost&#39;,
            &#39;username&#39; => &#39;root&#39;,
            &#39;password&#39; => &#39;root&#39;,
            &#39;port&#39; => 21

) ;
 
$ftp = new Ftp();
$ftp->connect($config);
$ftp->upload(&#39;ftp_err.log&#39;,&#39;ftp_upload.log&#39;);
$ftp->download(&#39;ftp_upload.log&#39;,&#39;ftp_download.log&#39;);



/*根据上面的三个协议写出基于ssh 的ftp 类
我们知道进行身份认证的方式有两种:公钥;密码 ;
(1) 使用密码登陆
(2) 免密码登陆也就是使用公钥登陆 

*/

class sftp{
	
	
	// 初始配置为NULL
	private  $config =NULL ;
	// 连接为NULL 
	private  $conn = NULL;

	
	// 是否使用秘钥登陆 
	 private $use_pubkey_file= false;
	
	// 初始化
	public function init($config){
		$this->config = $config ; 
	}
	
	
	// 连接ssh ,连接有两种方式(1) 使用密码
	// (2)  使用秘钥 
	public function connect(){
		
		$methods[&#39;hostkey&#39;] =  $use_pubkey_file ?  &#39;ssh-rsa&#39;  : [] ; 
		$con = ssh2_connect($this->config[&#39;host&#39;], $this->config[&#39;port&#39;], $methods);
		//(1) 使用秘钥的时候 
		if($use_pubkey_file){
		//  用户认证协议
			 $rc = ssh2_auth_pubkey_file(
				$conn,
				$this->config[&#39;user&#39;],
				$this->config[&#39;pubkey_file&#39;],
				$this->config[&#39;privkey_file&#39;],
				$this->config[&#39;passphrase&#39;]) 
			);
		//(2) 使用登陆用户名字和登陆密码
		}else{
			$rc = ssh2_auth_password( $conn, $this->conf_[&#39;user&#39;],$this->conf_[&#39;passwd&#39;]);
            
		}
		
		return $rc ;  
	}
	
	
	// 传输数据  传输层协议,获得数据
	   public function download($remote, $local){
		   
		    return ssh2_scp_recv($this->conn_, $remote, $local);
	   }
	   
	  //传输数据  传输层协议,写入ftp服务器数据
	  public function upload($remote, $local,$file_mode=0664){
		   return ssh2_scp_send($this->conn_, $local, $remote, $file_mode);
		    
	  }
	  
	  // 删除文件  
	    public function remove($remote){
			$sftp = ssh2_sftp($this->conn_);
			$rc   = false;

        if (is_dir(ssh2.sftp://{$sftp}/{$remote})) {
			$rc = false ;
			
			// ssh 删除文件夹
            $rc = ssh2_sftp_rmdir($sftp, $remote);
			} else {
		    // 删除文件
				$rc = ssh2_sftp_unlink($sftp, $remote);
			}
			return $rc;
			
		}
		  
  
 
	
}


$config  = [
    host          => 192.168.1.1 ,      //  ftp地址
    user          => ***, 
    port          => 22,
    pubkey_path  => /root/.ssh/id_rsa.pub,   // 公钥的存储地址
    privkey_path => /root/.ssh/id_rsa,          // 私钥的存储地址
];

$handle = new SftpAccess();
$handle->init($config);
$rc = $handle->connect();
$handle->getData(remote, $local);
		

		
/*		
 

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境