file_helper.html 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  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>文件辅助函数 - 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/helpers/file_helper.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;文件辅助函数 </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>文件辅助函数</h1>
  61. <p>文件辅助函数文件包含若干对文件进行操作的函数。</p>
  62. <h2>加载</h2>
  63. <p>使用以下代码:</p>
  64. <code>$this-&gt;load-&gt;helper('file');</code>
  65. <p>加载后可用以下函数:</p>
  66. <h2>read_file&#40;'<var>path</var>'&#41;</h2>
  67. <p>返回路径为path的文件内容。例:</p>
  68. <code>$string = read_file&#40;'./path/to/file.php'&#41;;</code>
  69. <p>可以是相对或者绝对的服务器的路径。如果函数执行失败则返回 FALSE(boolean类型)。</p>
  70. <p class="important"><strong>提示:</strong> 这里的路径是相对于该站点的index.php所在的路径,而不是当前所在的控制器或视图文件的路径。这是因为CodeIgniter使用的前端控制器(front controller)所以,所有的路径永远都是相对于index.php所在路径。</p>
  71. <p>如果你的服务器打开了 open_basedir 限制,你可能无法通过上面的方法访问一个文件。</p>
  72. <h2>write_file&#40;'<var>path</var>', <kbd>$data</kbd>&#41;</h2>
  73. <p>写进数据到path所指向文件。如果文件不存在则创建之。例:</p>
  74. <code>
  75. $data = 'Some file data';<br />
  76. <br />
  77. if ( ! write_file&#40;'./path/to/file.php', $data&#41;)<br />
  78. &#123;<br />
  79. &nbsp;&nbsp;&nbsp;&nbsp; echo 'Unable to write the file';<br />
  80. &#125;<br />
  81. else<br />
  82. &#123;<br />
  83. &nbsp;&nbsp;&nbsp;&nbsp; echo 'File written!';<br />
  84. &#125;</code>
  85. <p>你可以通过可选的第三个参数来设置文件的读写属性:</p>
  86. <code>write_file&#40;'./path/to/file.php', $data, <var>'r+'</var>&#41;;</code>
  87. <p>默认读写属性是 <kbd>wb</kbd>。更多关于文件读写属性参数的内容请参考:<a href="#">PHP user guide</a>。</p>
  88. <p>注意:要使用此函数写进数据,当前用户对此文件应该是“可写”的,如果该文件不存在则该用户应该对包含该文件的目录有写权限。(即*nux系统下的666,777等)。</p>
  89. <p class="important"><strong>提示:</strong> 这里的路径是相对于该站点的index.php所在的路径,而不是当前所在的控制器或视图文件的路径。这是因为CodeIgniter使用的前端控制器(front controller)所以,所有的路径永远都是相对于index.php所在路径。</p>
  90. <h2>delete_files('<var>path</var>')</h2>
  91. <p>删除所有包含于path下的文件。例:</p>
  92. <code>delete_files('./path/to/directory/');</code>
  93. <p>如果第二个参数设为 <kbd>true</kbd>, 则所有在path下的文件夹也会被删除掉。例:</p>
  94. <code>delete_files('./path/to/directory/', TRUE);</code>
  95. <p class="important"><strong>提示:</strong> 要被删除的文件必须是当前系统用户所有或者是当前用户对之具有写权限。</p>
  96. <h2>get_filenames('<var>path/to/directory/</var>')</h2>
  97. <p>获取path/to/directory目录下所有文件名组成的数组。如果需要文件名中有其完整路径则可以设置可选的第二个参数为TRUE。</p>
  98. <h2>get_dir_file_info('<var>path/to/directory/</var>', <kbd>$top_level_only</kbd> = TRUE)</h2>
  99. <p>获取path/to/directory/目录下的所有文件的文件名,文件大小,日期,文件权限等,并将这些内容保存到返回的数组当中。Sub-folders contained within the specified path are only read if forced
  100. by sending the second parameter, <kbd>$top_level_only</kbd> to <samp>FALSE</samp>, as this can be an intensive operation.</p>
  101. <h2>get_file_info('<var>path/to/file</var>', <kbd>$file_information</kbd>)</h2>
  102. <p>通过给定的路径和文件名,获取到文件path/to/file的文件名,文件大小,文件更改日期等。第二个参数允许你说明需要返回的信息,这个参数的选项包括'name', 'server_path', 'size', 'date', 'readable', 'writable', 'executable', 'fileperms'。如果文件不存在则返回FALSE。</p>
  103. <p class="important"><strong>注意:</strong> 参数 &quot;writable&quot; 是使用PHP内部的 is_writable() 函数来得到文件读写权限信息的,而这个函数在IIS服务器上存在众所周知的问题。为此,可以考虑使用PHP内部的另一个函数来替换,这个函数就是fileperms()。</p>
  104. <h2>get_mime_by_extension('<var>file</var>')</h2>
  105. <p>将文件后缀所代表的文件类型按照config/mimes.php里所指明的对应类型进行解释。如果不能决定文件类型,或者不能打开mime配置文件则返回 FALSE。</p>
  106. <p>
  107. <code>$file = &quot;somefile.png&quot;;<br />
  108. echo $file . ' is has a mime type of ' . get_mime_by_extension($file);</code>
  109. </p>
  110. <p class="critical"><strong>注意:</strong> 这并不是一个准确判断文件类型的方式,而仅仅是一种方便的判别方式。不应当在涉及安全问题时使用这种方式。</p>
  111. <h2>symbolic_permissions(<kbd>$perms</kbd>)</h2>
  112. <p>将数字式的权限表示方式(如<kbd>fileperms()</kbd>函数所返回值)转换成采用标准符号的标示方式,例如:"33279"转换成"-rwxrwxrwx")。</p>
  113. <code>echo symbolic_permissions(fileperms('./index.php'));<br />
  114. <br />
  115. // -rw-r--r--</code>
  116. <h2>octal_permissions(<kbd>$perms</kbd>)</h2>
  117. <p>将数字式的权限表示方式(如<kbd>fileperms()</kbd>函数所返回值)转换成采用三字符的八进制的标示方式,例如:"33279"转换成"777")。</p>
  118. <code>echo octal_permissions(fileperms('./index.php'));<br />
  119. <br />
  120. // 644</code><p>&nbsp;</p>
  121. <div id="Contributors">
  122. 翻译贡献者:
  123. Hex, iptton, pipi95, szlinz</div>
  124. <div id="DocDate">
  125. 最后修改: 2011-02-01 00:18:20</div>
  126. </div>
  127. <!-- END CONTENT -->
  128. <div id="footer">
  129. <p>
  130. 上一个主题:&nbsp;&nbsp;<a href="directory_helper.html">目录辅助函数</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  131. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="form_helper.html">表单辅助函数</a> </p>
  132. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  133. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  134. </div>
  135. </body>
  136. </html>