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); } }
try doing it!
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。