[PHP学习教程 - 类库]002.FTP操作(FTP)
引言:FTP是大家上传至站点服务器必须要使用的协议。现在常用的FTP客户端工具也很多,如:8uftp,FlashFXP,...。但是使用客户端工具就无法真正与自动化联系起来。所以今天,我们为大家讲一下怎么用PHP使用FTP命令,实现文件的上传与下载。
导航索引:
大家请看下文。
概念
百科定义:
FTP 是File Transfer Protocol(文件传输协议)的英文简称,而中文简称为“文传协议”。用于Internet上的控制文件的双向传输。同时,它也是一个应用程序(Application)。 基于不同的操作系统有不同的FTP应用程序,而所有这些应用程序都遵守同一种协议以传输文件。在FTP的使用当中,用户经常遇到两个概念:"下载" (Download)和"上传"(Upload)。"下载"文件就是从远程主机拷贝文件至自己的计算机上;"上传"文件就是将文件从自己的计算机中拷贝至远程主机上。用Internet语言来说,用户可通过客户机程序向(从)远程主机上传(下载)文件。
使用方式:
TCP/IP协议中,FTP标准命令TCP端口号为21,Port方式数据端口为20。FTP的任务是从一台计算机将文件传送到另一台计算机,不受操作系统的限制。
FTP常用API
函数API很多,我们直接上代码:
- <?php
- // 连接FTP服务器
- $conn = ftp_connect("ftp.server.com");
- // 使用“账号”和“密码”登录
- ftp_login($conn, "ac", "superdo");
- // 获取远端系统类型
- ftp_systype($conn);
- // 列出文件清单
- $filelist = ftp_nlist($conn, ".");
- // 下载文件
- ftp_get($conn, "data.zip", "data.zip", FTP_BINARY);
- // 关闭连接
- ftp_quit($conn);
- // 说明:初结化一个FTP联接,PHP提供了ftp_connect()这个函数,它使用主机名称和端口作为参数。在上面的例子里,主机名字为 "ftp.server.com";如果端口没指定,PHP将会使用"21"作为缺省端口来建立联接。
- // 联接成功后ftp_connect()传回一个handle句柄;这个handle将被以后使用的FTP函数使用。
- $conn = ftp_connect("ftp.server.com");
- // 一旦建立联接,使用ftp_login()发送一个用户名称和用户密码。你可以看到,这个函数ftp_login()使用了 ftp_connect()函数传来的handle,以确定用户名和密码能被提交到正确的服务器。
- ftp_login($conn, "ac", "superdo");
- // 关闭连接
- ftp_quit($conn);
- // 登录了FTP服务器,PHP提供了一些函数,它们能获取一些关于系统和文件以及目录的信息。
- ftp_pwd()
- // 获取当前所在的目录
- $here = ftp_pwd($conn);
- // 获取服务器端系统信息ftp_systype()
- $server_os = ftp_systype($conn);
- // 被动模式(PASV)的开关,打开或关闭PASV(1表示开)
- ftp_pasv($conn, 1);
- // 进入目录中用ftp_chdir()函数,它接受一个目录名作为参数。
- ftp_chdir($conn, "public_html");
- // 回到所在的目录父目录用ftp_cdup()实现
- ftp_cdup($conn);
- // 建立或移动一个目录,这要使用ftp_mkdir()和ftp_rmdir()函数;注意:ftp_mkdir()建立成功的话,就会返回新建立的目录名。
- ftp_mkdir($conn, "test");
- ftp_rmdir($conn, "test");
- // 上传文件,ftp_put()函数能很好的胜任,它需要你指定一个本地文件名,上传后的文件名以及传输的类型。比方说:如果你想上传 "abc.txt"这个文件,上传后命名为"xyz.txt",命令应该是这样:
- ftp_put($conn, "xyz.txt", "abc.txt", FTP_ASCII);
- // 下载文件:PHP所提供的函数是ftp_get(),它也需要一个服务器上文件名,下载后的文件名,以及传输类型作为参数,例如:服务器端文件为his.zip,你想下载至本地机,并命名为hers.zip,命令如下:
- ftp_get($conn, "hers.zip", "his.zip", FTP_BINARY);
- // 说明:PHP提供两种方法:一种是简单列示文件名和目录,另一种就是详细的列示文件的大小,权限,创立时间等信息。
- // 第一种使用ftp_nlist()函数,第二种用ftp_rawlist().两种函数都需要一个目录名做为参数,都返回目录列做为一个数组,数组的每一个元素相当于列表的一行。
- $filelist = ftp_nlist($conn, ".");
- // 函数ftp_size(),它返回你所指定的文件的大小,使用BITES作为单位。要指出的是,如果它返回的是 "-1"的话,意味着这是一个目录
- $filelist = ftp_size($conn, "data.zip");
FTP封装类
直接上高清无MSK的工具类:
- <?php
- // +----------------------------------------------------------------------
- // | Tool.Pub [ All tools in it! ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2015 http://www.tool.pub All rights reserved.
- // +----------------------------------------------------------------------
- // | Author: AC.Cai <c1985@vip.qq.com> <http://do.org.cn>
- // +----------------------------------------------------------------------
- /**
- * FTP工具类
- */
- class FTP
- {
- public $off; // 返回操作状态(成功/失败)
- public $conn_id; // FTP连接
- /**
- * 方法:FTP连接
- *
- * @FTP_HOST -- FTP主机
- * @FTP_PORT -- 端口
- * @FTP_USER -- 用户名
- * @FTP_PASS -- 密码
- */
- public function __construct($FTP_HOST,$FTP_PORT,$FTP_USER,$FTP_PASS)
- {
- $this->conn_id = @ftp_connect($FTP_HOST, $FTP_PORT) or die("FTP服务器连接失败");
- @ftp_login($this->conn_id, $FTP_USER, $FTP_PASS) or die("FTP服务器登陆失败");
- @ftp_pasv($this->conn_id, 1); // 打开被动模拟
- }
- /**
- * 方法:上传文件
- *
- * @path -- 本地路径
- * @newpath -- 上传路径
- * @type -- 若目标目录不存在则新建
- */
- public function up_file($path, $newpath, $type = true)
- {
- if ($type)
- {
- $this->dir_mkdirs($newpath);
- }
- $this->off = @ftp_put($this->conn_id, $newpath, $path, FTP_BINARY);
- if (!$this->off)
- {
- echo "文件上传失败,请检查权限及路径是否正确!";
- }
- }
- /**
- * 方法:移动文件
- *
- * @path -- 原路径
- * @newpath -- 新路径
- * @type -- 若目标目录不存在则新建
- */
- public function move_file($path, $newpath, $type = true)
- {
- if ($type)
- {
- $this->dir_mkdirs($newpath);
- }
- $this->off = @ftp_rename($this->conn_id, $path, $newpath);
- if (!$this->off)
- {
- echo "文件移动失败,请检查权限及原路径是否正确!";
- }
- }
- /**
- * 方法:复制文件
- * 说明:由于FTP无复制命令,本方法变通操作为:下载后再上传到新的路径
- *
- * @path -- 原路径
- * @newpath -- 新路径
- * @type -- 若目标目录不存在则新建
- */
- public function copy_file($path, $newpath, $type = true)
- {
- $downpath = "c:/tmp.dat";
- $this->off = @ftp_get($this->conn_id, $downpath, $path, FTP_BINARY);// 下载
- if (!$this->off)
- {
- echo "文件复制失败,请检查权限及原路径是否正确!";
- }
- $this->up_file($downpath, $newpath, $type);
- }
- /**
- * 方法:删除文件
- *
- * @path -- 路径
- */
- public function del_file($path)
- {
- $this->off = @ftp_delete($this->conn_id, $path);
- if (!$this->off)
- {
- echo "文件删除失败,请检查权限及路径是否正确!";
- }
- }
- /**
- * 方法:生成目录
- * @path -- 路径
- */
- public function dir_mkdirs($path)
- {
- $path_arr = explode('/', $path); // 取目录数组
- $file_name = array_pop($path_arr); // 弹出文件名
- $path_div = count($path_arr); // 取层数
- foreach ($path_arr as $val) // 创建目录
- {
- if (@ftp_chdir($this->conn_id, $val) == FALSE)
- {
- $tmp = @ftp_mkdir($this->conn_id, $val);
- if ($tmp == FALSE)
- {
- echo "目录创建失败,请检查权限及路径是否正确!";
- exit;
- }
- @ftp_chdir($this->conn_id, $val);
- }
- }
- for ($i = 1; $i <= $path_div; $i++) // 回退到根
- {
- @ftp_cdup($this->conn_id);
- }
- }
- /**
- * 方法:关闭FTP连接
- */
- public function close()
- {
- @ftp_close($this->conn_id);
- }
- }
- // class class_ftp end
示例1:
- $ftp = new FTP('127.0.0.1', 21, 'ac','superdo'); // 打开FTP连接
- $ftp->up_file('h.wav', 'xxoo/h.wav'); // 上传文件
- // $ftp->move_file('h/h.php','h.php'); // 移动文件
- // $ftp->copy_file('h.php','h/h.php'); // 复制文件
- // $ftp->del_file('h.php'); // 删除文件
- $ftp->close(); // 关闭FTP连接
其他
功能说明:
PHP用FTP函数创建目录
函数说明:
只是抛砖引玉供大家参 考学习,做网站时考虑前后台分离,可以使用这种文法,直接把静态页生成到另一台服务器上使用。
- <?php
- // create directory through FTP connection
- function ftpMkdir($path, $newDir)
- {
- $server = 'ftp.yourserver.com'; // ftp server
- $connection = ftp_connect($server); // connection
- // login to ftp server
- $user = "me";
- $pass = "password";
- $result = ftp_login($connection, $user, $pass);
- // check if connection was made
- if ((!$connection) || (!$result))
- {
- return false;
- exit();
- }
- else
- {
- ftp_chdir($connection, $path); // go to destination dir
- if (ftp_mkdir($connection, $newDir)) // create directory
- {
- return $newDir;
- }
- else
- {
- return false;
- }
- ftp_close($conn_id); // close connection
- }
- }
结束语
FTP虽然古老,但是的确是一个好东西,近几个月我们在利用shell及python做框架及工具环境的自动化同步,出包(ios/and/win)。传输途径主要是借助于shell,大家知道,shell是无法在windows机器上直接运行的,需要借助其他的容器,也就是要借尸还魂。不利于屏蔽操作系统来操作,也就是不能做到全兼容,无奈之下,之前的几个月购了一台Mac Pro,其实现在回头想想,如果当时有想到FTP来解决,Mac Pro就不用买了,经验之谈,发发牢骚!谢谢大家的观看。
未完,待更新...
本站文章为宝宝巴士 SD.Team原创,转载务必在明显处注明:(作者官方网站:宝宝巴士)
转载自【宝宝巴士SuperDo团队】 原文链接: http://www.cnblogs.com/superdo/p/4825137.html
[PHP学习教程 - 类库]002.FTP操作(FTP)的更多相关文章
- [PHP学习教程 - 文件]002.修改上传文件大小限制(File Upload Limit)
引言:通常大家直装xampp之后,默认的文件上传大小应该被设定成2M左右,这个时候如果上传超过2M的东西,就会报错,让人非常尴尬.如何修改呢? 导航索引: 概念 FTP常用API FTP封装类 其他 ...
- 迷你MVVM框架 avalonjs 学习教程9、类名操作
ms-class是avalon用得最多的几个绑定之一,也正因为如此其功能一直在扩充中.根据时期的不同,分为旧风格与新风格两种. 旧风格是指ms-class-xxx=”expr”,*ms-class-a ...
- 迷你MVVM框架 avalonjs 学习教程8、属性操作
属性操作是DOM操作很大的一块,它包括类名操作,表单元素的value属性操作,元素固有属性的管理,元素自定义属性的管理,某些元素的一些布尔属性的操作.大多数情况下,元素属性的值是字符串类型,我们称之为 ...
- [PHP学习教程 - 文件]002.判断远程文件是否存在(Remote File Exists)
引言:项目过程当中碰到了类似流程这样的需求,对服务器上的文件进行依次操作,如:检查文件格式->检查文件是否有更新->处理更新->同步其他服务器等等 如果需求的操作是依赖于远程文件是否 ...
- [PHP学习教程 - 网络]002.获取网页内容(URL Content)
引言:获取网页内容是我们实现网页操作的基本之基本,今天这一讲,我们和大家讲一下基本请求网页内容的几种方法. 我们似乎每天都要做这样一件事情,打开一个浏览器,输入网址,回车,一个空白的页面顿时有了东西, ...
- 迷你MVVM框架 avalonjs 学习教程10、样式操作
一般情况下我们通过设置类名就可以改变元素的样式,但涉及到动画部分,就一定需要设置内联样式了,因此有了ms-css.*ms-css*的用法为ms-css-样式名="样式值", 如ms ...
- [PHP学习教程 - 网络]002.$_SERVER["SCRIPT_NAME"]、$_SERVER["PHP_SELF"]、$_SERVER["QUERY_STRING"]、$_SERVER["REQUEST_URI"]介绍($_SERVER URL Infomation)
引言:在使用原生PHP的时候,对于URL路径的切割,如:域名,查询参数等等的提取,通常绝大多数兄弟会忽略$_SERVER中定义的内置常量的关系,这里为大家讲解一下. 常用的URL请求路径$_SERVE ...
- [PHP学习教程 - 类库]001.全局唯一ID(GUID)
GUID: 即Globally Unique Identifier(全球唯一标识符) 也称作 UUID(Universally Unique IDentifier) . GUID 是一个通过特定算法产 ...
- [PHP学习教程 - 系统]002.模拟守护进程(Daemon)-程序永远在后台运行
引言:如何模拟那些自动轮循的服务,像守护进程(Daemon)那样,可以一直执行,永不停歇呢! Come on! Do it! Do! Do! Do!.... 使用接口: int ignore_user ...
随机推荐
- USACO Training Section 1.3混合牛奶 Mixing Milk
题目描述 由于乳制品产业利润很低,所以降低原材料(牛奶)价格就变得十分重要.帮助Marry乳业找到最优的牛奶采购方案. Marry乳业从一些奶农手中采购牛奶,并且每一位奶农为乳制品加工企业提供的价格是 ...
- 图论--二分图最佳完美匹配(KM模板)
#include <iostream> #include <cstring> #include <cstdio> using namespace std; cons ...
- alerta 集中化告警信息 -zabbix
Docker安装Alerta https://hub.docker.com/D/alerta/alerta-web/ How to use this image To use this image ...
- 虚拟化云计算平台Proxmox VE
1.虚拟化技术介绍 1.1.OpenVZ 简介 OpenVZ 是开源软件, 是基于Linux平台的操作系统级服务器虚拟化解决方案,它是基于Linux内核和作业系统的操作系统级虚拟化技术. OpenVZ ...
- uiautomatorviewer 出现安卓8.0级以上无法打开的解决方法
一..本人在使用Android自带的uiautomatorviewer工具来进行app元素定位时,出现了Android 9.0打开不了.出现了如下图错误提示: 经过网上的查阅,总结了几个解决的方法. ...
- Java——字节和字符的区别
字节 1.bit=1 二进制数据0或1 2.byte=8bit 1个字节等于8位 存储空间的基本计量单位 3.一个英文字母=1byte=8bit 1个英文字母是1个字节,也就是8位 4.一个汉字= ...
- 《C程序设计语言》 练习2-3
问题描述 < class="title-article"> 练习2-3 编写函数htoi(s),把由16进制数字组成的字符串(包含可选的前缀0X或0x)转换成与之等价的 ...
- 记录关于Android多线程的一个坑
最近在写项目的时候由于联网用得比较频繁,就简单地封装了一个工具类,省得每次联网得时候都要把联网配置写一遍,代码如下: public class okhttp_plus { public static ...
- android的布局 (如何实现空心圆效果的布局)
layer-list : 简单来说layer-list就是图层列表的意思,是用来创建LayerDrawable的,LayerDrawable是DrawableResource的一种,所以,layer- ...
- TP5 order排序
order方法属于模型的连贯操作方法之一,用于对操作的结果排序. ->order('sort desc,id desc') 用法如下: Db::table('think_user')->w ...