ftp.html 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0" />
  6. <title>FTP 类 - CodeIgniter 中文手册|用户手册|用户指南|Wiki文档</title>
  7. <link rel="shortcut icon" href="http://codeigniter.org.cn/user_guide/../images/design/favicon.ico" type="image/x-icon" />
  8. <link rel="stylesheet" type="text/css" media="all" href="../userguide.css" />
  9. <link rel="search" href="http://codeigniter.org.cn/user_guide/../CodeIgniterSearch.xml" type="application/opensearchdescription+xml" title="CodeIgniter 搜索"/>
  10. <link rel="canonical" href="http://codeigniter.org.cn/user_guide/libraries/ftp.html" />
  11. <script type="text/javascript" src="../nav/mootools.js-ver=20130324.js"></script>
  12. <script type="text/javascript" src="../nav/mootools-more.js-ver=20130324.js"></script>
  13. <script type="text/javascript" src="../nav/nav.js-ver=20130324.js"></script>
  14. <script type="text/javascript" src="../nav/user_guide_menu.js-ver=20130324.js"></script>
  15. <meta name="robots" content="all" />
  16. <meta name="author" content="ExpressionEngine Dev Team" />
  17. <meta name="description" content="CodeIgniter 中文手册, CodeIgniter 用户指南, CodeIgniter User Guide, Wiki 文档" />
  18. </head>
  19. <body>
  20. <!-- START NAVIGATION -->
  21. <div id="nav">
  22. <div id="nav_inner">
  23. <script type="text/javascript">create_menu('../');</script>
  24. </div>
  25. </div>
  26. <script type="text/javascript">_setNavigation();</script>
  27. <div id="nav2"><a name="top"></a><a href="javascript:void(0);" onclick="myHeight.toggle();"><img src="../images/nav_toggle_darker.jpg" width="154" height="43" border="0" title="切换目录" alt="切换目录" /></a></div>
  28. <div id="masthead" class="clearfix">
  29. <div class="topbar-hd"><h1>CodeIgniter 用户指南 版本 2.2.0</h1></div>
  30. <div class="topbar-tip">编辑文档、查看近期更改请 <a href="#">登录</a> 或 <a href="#">注册</a>  <a href="#">找回密码</a></div> <div id="breadcrumb_right"><a href="../toc.html">目录页</a></div>
  31. </div>
  32. <!-- END NAVIGATION -->
  33. <!-- START BREADCRUMB -->
  34. <table cellpadding="0" cellspacing="0" border="0" style="width:100%">
  35. <tr>
  36. <td id="breadcrumb">
  37. <a href="#" target="_blank">CodeIgniter 中国首页</a>&nbsp;&#8250;&nbsp;
  38. <a href="../index.html">用户指南首页</a>&nbsp;&#8250;&nbsp;FTP 类 </td>
  39. <td id="searchbox">
  40. <form method="get" action="http://www.google.com.hk/search" target="google_window">
  41. <input type="hidden" name="client" value="pub-0176846097796333"></input>
  42. <input type="hidden" name="forid" value="1"></input>
  43. <input type="hidden" name="ie" value="UTF-8"></input>
  44. <input type="hidden" name="oe" value="UTF-8"></input>
  45. <input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.org.cn/user_guide/" />
  46. 搜索用户指南&nbsp;
  47. <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" />
  48. &nbsp;
  49. <input type="submit" class="submit" name="sa" value="Go" />
  50. </form>
  51. </td>
  52. </tr>
  53. </table>
  54. <!-- END BREADCRUMB -->
  55. <div style="clear:both;text-align:right;padding: 6px 40px 0 0;">
  56. <a href="#" target="_blank">查看原文</a>
  57. </div>
  58. <!--<br clear="all" />--><!-- START CONTENT -->
  59. <div id="content">
  60. <h1>FTP 类</h1>
  61. <p>CodeIgniter的FTP类允许你将本地文件传输到远程服务器上,同时可以移动、重命名和删除远程服务器上的文件。这个FTP类所包含的一个&quot;mirroring&quot;函数允许你通过FTP在远程服务器上创建一个本地文件夹的镜像。</p>
  62. <p class="important"><strong>注意:</strong>&nbsp;不支持 SFTP 和 SSL FTP 协议, 仅支持标准 FTP 协议.</p>
  63. <h2>初始化类</h2>
  64. <p>像大多数其他CodeIgniter 类一样,FTP 类在控制器里使用<dfn>$this-&gt;load-&gt;library</dfn> 函数来初始化:</p>
  65. <p><code>$this-&gt;load-&gt;library('ftp');</code></p>
  66. <p>一旦加载, FTP对象就可以使用: <dfn>$this-&gt;ftp</dfn></p>
  67. <h2>使用例子</h2>
  68. <p>在这个例子中,首先建立一个到FTP服务器的连接,接着读取一个本地文件然后以ASCII模式上传。文件的权限被设置为755。</p>
  69. <p><code>$this-&gt;load-&gt;library('ftp');<br />
  70. <br />
  71. $config['hostname'] = 'ftp.example.com';<br />
  72. $config['username'] = 'your-username';<br />
  73. $config['password'] = 'your-password';<br />
  74. $config['debug'] = TRUE;<br />
  75. <br />
  76. $this-&gt;ftp-&gt;connect($config);<br />
  77. <br />
  78. $this-&gt;ftp-&gt;upload('/local/path/to/myfile.html', '/public_html/myfile.html', 'ascii', 0775);<br />
  79. <br />
  80. $this-&gt;ftp-&gt;close(); </code></p>
  81. <p>下面的例子从FTP服务器上获得了文件列表</p>
  82. <p><code>$this-&gt;load-&gt;library('ftp');<br />
  83. <br />
  84. $config['hostname'] = 'ftp.example.com';<br />
  85. $config['username'] = 'your-username';<br />
  86. $config['password'] = 'your-password';<br />
  87. $config['debug'] = TRUE;<br />
  88. <br />
  89. $this-&gt;ftp-&gt;connect($config);<br />
  90. <br />
  91. $list = $this-&gt;ftp-&gt;list_files('/public_html/');<br />
  92. <br />
  93. print_r($list);<br />
  94. <br />
  95. $this-&gt;ftp-&gt;close(); </code></p>
  96. <p>下面的例子在FTP服务器上创建了一个本地文件夹的镜像。</p>
  97. <p><code>$this-&gt;load-&gt;library('ftp');<br />
  98. <br />
  99. $config['hostname'] = 'ftp.example.com';<br />
  100. $config['username'] = 'your-username';<br />
  101. $config['password'] = 'your-password';<br />
  102. $config['debug'] = TRUE;<br />
  103. <br />
  104. $this-&gt;ftp-&gt;connect($config);<br />
  105. <br />
  106. $this-&gt;ftp-&gt;mirror('/path/to/myfolder/', '/public_html/myfolder/');<br />
  107. <br />
  108. $this-&gt;ftp-&gt;close(); </code></p>
  109. <h1>函数参考</h1>
  110. <h2>$this-&gt;ftp-&gt;connect()</h2>
  111. <p>连接并登录到FTP服务器,通过向函数传递一个数组来设置连接参数,或者你可以把这些参数保存在一个配置文件中。</p>
  112. <p>下面例子演示了如何手动设置参数:</p>
  113. <p><code>$this-&gt;load-&gt;library('ftp');<br />
  114. <br />
  115. $config['hostname'] = 'ftp.example.com';<br />
  116. $config['username'] = 'your-username';<br />
  117. $config['password'] = 'your-password';<br />
  118. $config['port']&nbsp;&nbsp;&nbsp;&nbsp; = 21;<br />
  119. $config['passive']&nbsp;&nbsp;= FALSE;<br />
  120. $config['debug']&nbsp;&nbsp;&nbsp;&nbsp;= TRUE;<br />
  121. <br />
  122. $this-&gt;ftp-&gt;connect($config);<br />
  123. </code></p>
  124. <h3>在配置文件中设置参数</h3>
  125. <p>如果你更倾向把FTP参数设置保存在一个配置文件中,只需创建一个名为<var>ftp.php</var>的文件, 把 <var>$config</var> 数组添加到该文件中,然后保存成<var>config/ftp.php</var> 它就会自动被读取。</p>
  126. <h3>可用连接选项:</h3>
  127. <ul>
  128. <li><strong>hostname</strong> - FTP主机名。 通常看起来是这样的:&nbsp; <dfn>ftp.example.com</dfn></li>
  129. <li><strong>username</strong> - FTP用户名。</li>
  130. <li><strong>password</strong> - FTP密码。</li>
  131. <li><strong>port</strong> - 端口号。 默认设置为<dfn>21</dfn></li>
  132. <li><strong>debug</strong> - <kbd>TRUE/FALSE</kbd> (布尔值). 是否开启调试显示错误信息。</li>
  133. <li><strong>passive</strong> - <kbd>TRUE/FALSE</kbd> (布尔值). 是否使用被动模式,默认设置为被动模式。</li>
  134. </ul>
  135. <h2>$this-&gt;ftp-&gt;upload()</h2>
  136. <p>将一个文件上传到你的服务器上。本地路径和远程路径这两个参数是必需的,而传输模式和权限设置这两个参数则是可选的。例如:</p>
  137. <p><code>$this-&gt;ftp-&gt;upload('/local/path/to/myfile.html', '/public_html/myfile.html', 'ascii', 0775);</code></p>
  138. <p><strong>传输模式包括:</strong>&nbsp; <kbd>ascii</kbd>, <kbd>binary</kbd>, 以及 <kbd>auto</kbd> (默认值)。如果使用了<kbd>auto</kbd>模式,将根据源文件的扩展名来自动选择传输模式。 </p>
  139. <p>设置权限,你可以将一个<kbd>octal</kbd> (八进制)的权限值通过第四个参数传递过去。</p>
  140. <h2>$this-&gt;ftp-&gt;download()</h2>
  141. <p>从你的服务器下载文件。你必须提供远程路径和本地路径,设置什么模式是可选的。例:</p>
  142. <code>$this-&gt;ftp-&gt;download('/public_html/myfile.html', '/local/path/to/myfile.html', 'ascii');</code>
  143. <p><strong>Mode options are:</strong>&nbsp; <kbd>ascii</kbd>, <kbd>binary</kbd>, and <kbd>auto</kbd> (the default). If
  144. <kbd>auto</kbd> is used it will base the mode on the file extension of the source file.</p>
  145. <p>如果下载失败返回 FALSE (包括 PHP 没有写入文件的权限的情况)</p>
  146. <h2>$this-&gt;ftp-&gt;rename()</h2>
  147. <p>作用是给一个文件重命名。请给出原文件名/路径和新的文件名/路径。</p>
  148. <p><code>// 将文件 green.html 重命名为 blue.html<br />
  149. $this-&gt;ftp-&gt;rename('/public_html/foo/green.html', '/public_html/foo/blue.html'); </code></p>
  150. <h2>$this-&gt;ftp-&gt;move()</h2>
  151. <p>作用是移动一个文件。请给出源路径和目标路径:</p>
  152. <p><code>// 将文件 blog.html 从 &quot;joe&quot; 移动到 &quot;fred&quot;<br />
  153. $this-&gt;ftp-&gt;move('/public_html/joe/blog.html', '/public_html/fred/blog.html'); </code></p>
  154. <p>说明: 如果源文件名与目标文件名不同,文件将会被重命名。</p>
  155. <h2>$this-&gt;ftp-&gt;delete_file&#40;&#41;</h2>
  156. <p>作用是删除一个文件。请给出源文件名和所在路径。</p>
  157. <p><code>$this-&gt;ftp-&gt;delete_file&#40;'/public_html/joe/blog.html'&#41;; </code></p>
  158. <h2>$this-&gt;ftp-&gt;delete_dir()</h2>
  159. <p>作用是删除一个目录以及此目录下的全部内容。请给出原目录的路径,并以斜线结束。</p>
  160. <p class="important"><strong>重要提示</strong>&nbsp; 请 非常谨慎 地使用这个函数。它将删除你给出的目录下的 <strong>所有内容</strong>,也就是说此目录下的所有子目录以及所有文件都会被删除。请确保你给出的路径是绝对正确的。可以先试着使用 <kbd>list_files()</kbd> 函数来验证你的路径是否正确。</p>
  161. <p><code>$this-&gt;ftp-&gt;delete_dir('/public_html/path/to/folder/'); </code></p>
  162. <h2>$this-&gt;ftp-&gt;list_files()</h2>
  163. <p>允许你检索你服务器上所有文件的列表,以<dfn>数组</dfn>的形式返回检索结果。你必须给出要检索的路径。</p>
  164. <p><code>$list = $this-&gt;ftp-&gt;list_files('/public_html/');<br />
  165. <br />
  166. print_r($list); </code></p>
  167. <h2>$this-&gt;ftp-&gt;mirror()</h2>
  168. <p>检索一个本地目录下的所有内容(包括子目录和所有文件),并通过FTP为这个目录创建一份镜像。源路径下的任何结构都会被创建到服务器上。你必须给出源路径和目标路径:</p>
  169. <p><code>$this-&gt;ftp-&gt;mirror('/path/to/myfolder/', '/public_html/myfolder/'); </code></p>
  170. <h2>$this-&gt;ftp-&gt;mkdir()</h2>
  171. <p>允许你在服务器上创建一个目录。请给出你想要创建的目录的完整路径,截止到你要创建的目录名,并在末尾添加斜线结束。你还可以在第二个参数中传递一个<kbd>八进制</kbd>的权限值。</p>
  172. <p><code>// 创建一个名为&quot;bar&quot;的目录<br />
  173. $this-&gt;ftp-&gt;mkdir('/public_html/foo/bar/', DIR_WRITE_MODE); </code></p>
  174. <h2>$this-&gt;ftp-&gt;chmod()</h2>
  175. <p>允许你设置文件权限。请给出你要设置的文件或者目录所在的路径:</p>
  176. <p><code>// 将 &quot;bar&quot; 的权限设置为 777<br />
  177. $this-&gt;ftp-&gt;chmod('/public_html/foo/bar/', DIR_WRITE_MODE); </code></p>
  178. <h2>$this-&gt;ftp-&gt;close();</h2>
  179. <p>关闭到服务器的连接。当你上传完毕时,建议使用这个函数关闭连接。</p><p>&nbsp;</p>
  180. <div id="Contributors">
  181. 翻译贡献者:
  182. dimitry, Hex, IT不倒翁, tg8866, yinzhili, yygcom</div>
  183. <div id="DocDate">
  184. 最后修改: 2012-02-06 00:44:15</div>
  185. </div>
  186. <!-- END CONTENT -->
  187. <div id="footer">
  188. <p>
  189. 上一个主题:&nbsp;&nbsp;<a href="form_validation.html">表单验证类</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  190. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="table.html">HTML 表格类</a> </p>
  191. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  192. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  193. </div>
  194. </body>
  195. </html>