用PHP實現一個FTP客戶端
php具有很好的擴展性,在php中對于ftp文件的上傳也是內置功能,和其他語言一樣,只能實現的是客戶端。
class FtpClient {
/**
* 上傳文件根目錄
* @var string
*/
private $rootPath;
/**
* 本地上傳錯誤信息
* @var string
*/
private $error = ''; //上傳錯誤信息
/**
* FTP連接
* @var resource
*/
private $link;
private $config = array(
'host' => '', //服務器
'port' => 21, //端口
'timeout' => 90, //超時時間
'username' => '', //用戶名
'password' => '', //密碼
);
/**
* 構造函數,用于設置上傳根路徑
* @param array $config FTP配置
*/
public function __construct($config){
/* 默認FTP配置 */
$this->config = array_merge($this->config, $config);
/* 登錄FTP服務器 */
if(!$this->login()){
E($this->error);
}
}
/**
* 檢測上傳根目錄
* @param string $rootpath 根目錄
* @return boolean true-檢測通過,false-檢測失敗
*/
public function checkRootPath($rootpath){
/* 設置根目錄 */
$this->rootPath = ftp_pwd($this->link) . '/' . ltrim($rootpath, '/');
if(!@ftp_chdir($this->link, $this->rootPath)){
$this->error = '上傳根目錄不存在!';
return false;
}
return true;
}
/**
* 檢測上傳目錄
* @param string $savepath 上傳目錄
* @return boolean 檢測結果,true-通過,false-失敗
*/
public function checkSavePath($savepath){
/* 檢測并創建目錄 */
if (!$this->mkdir($savepath)) {
return false;
} else {
//TODO:檢測目錄是否可寫
return true;
}
}
/**
* 保存指定文件
* @param array $file 保存的文件信息
* @param boolean $replace 同名文件是否覆蓋
* @return boolean 保存狀態,true-成功,false-失敗
*/
public function save($file, $replace=true) {
$filename = $this->rootPath . $file['savepath'] . $file['savename'];
/* 不覆蓋同名文件 */
// if (!$replace && is_file($filename)) {
// $this->error = '存在同名文件' . $file['savename'];
// return false;
// }
/* 移動文件 */
if (!ftp_put($this->link, $filename, $file['tmp_name'], FTP_BINARY)) {
$this->error = '文件上傳保存錯誤!';
return false;
}
return true;
}
/**
* 創建目錄
* @param string $savepath 要創建的穆里
* @return boolean 創建狀態,true-成功,false-失敗
*/
public function mkdir($savepath){
$dir = $this->rootPath . $savepath;
if(ftp_chdir($this->link, $dir)){
return true;
}
if(ftp_mkdir($this->link, $dir)){
return true;
} elseif($this->mkdir(dirname($savepath)) && ftp_mkdir($this->link, $dir)) {
return true;
} else {
$this->error = "目錄 {$savepath} 創建失敗!";
return false;
}
}
/**
* 創建目錄
* @param string $file 目標文件或者目錄
* @return real 文件大小或者-1
*/
public function filesize($file)
{
return @ftp_size($this->link,$file);
}
/**
* 獲取最后一次上傳錯誤信息
* @return string 錯誤信息
*/
public function getError(){
return $this->error;
}
/**
* 給文件或者目錄授權
* @param String $file 文件或者路徑
* @param $mode 八進制權限值 1- 執行權限,2-寫權限,4 - 讀權限 0644->所有者可讀寫,其他人可讀
* @return 設置成功的新權限或者失敗時false
*/
public function chmod($file,$mode)
{
if(!ftp_chmod(($this->link,$mode,$file))
{
$this->error = '授權失敗';
}
}
/**
* @param string path 必需。規定要刪除的文件的路徑
* @return true or false
*/
public function delete($path)
{
if (!ftp_delete($this->link, $path)) {
$this->error ='刪除文件:'.$path.' 失敗';
}
}
/**
* @param string local 必需。本地文件存儲路徑
* @param string remote 必需。遠程文件路徑
* @param string mode 必需。讀取模式
* @param string resume 讀取文件大小的起始位置
* @return true or false
*/
public function fetch($local,$remote,$mode,$resume=0)
{
$arr_mode = array(FTP_ASCII,FTP_BINARY);
if(!in_array($mode, $arr_mode))
{
$mode = FTP_BINARY;
}
if(!ftp_get($this->link,$local,$remote,$mode,$resume))
{
$this->error ='讀取遠程文件:'.$remote.' 失敗';
}
}
/**
* 登錄到FTP服務器
* @return boolean true-登錄成功,false-登錄失敗
*/
private function login(){
extract($this->config);
$this->link = ftp_connect($host, $port, $timeout);
if($this->link) {
if (ftp_login($this->link, $username, $password)) {
return true;
} else {
$this->error = "無法登錄到FTP服務器:username - {$username}";
}
} else {
$this->error = "無法連接到FTP服務器:{$host}";
}
return false;
}
/**
* 析構方法,用于斷開當前FTP連接
*/
public function __destruct() {
ftp_close($this->link);
}
}來自:http://my.oschina.net/ososchina/blog/345745 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!