validation.html 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735
  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/libraries/validation.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. <p class="important">
  61. 这个类库已经废弃掉了。鼓励使用 form_validation 类库。
  62. </p>
  63. <h1>表单验证</h1>
  64. <p>在解释CodeIgniter的数据验证前,让我们先描述下理想情况:</p>
  65. <ol>
  66. <li>显示一个表单;</li>
  67. <li>你填写文字并点击提交按钮;</li>
  68. <li>如果你提交的东西是残缺的,又或者漏填了必须填写的项,表单重新显示并包含你提交数据的一条错误信息;</li>
  69. <li>这个过程继续,直到你提交了正确的信息</li>
  70. </ol>
  71. <p>在这个过程中,程序必须:</p>
  72. <ol>
  73. <li>检查必须的数据。</li>
  74. <li>校验数据的格式是否正确,是否符合标准(比如,如果提交用户名,那么必须只能包含有效的字符。必须有最小的长度,并且不能超过允许的长度。 用户名不可以与已有用户名重复,或者不能为保留字,等等。 Etc.)</li>
  75. <li>处理数据使之更安全。</li>
  76. <li>需要的情况下预格式化数据(数据需要进行剪裁,HTML格式化?等等)。</li>
  77. <li>准备数据,写入数据库。</li>
  78. </ol>
  79. <p>尽管上面的过程没有什么复杂的地方,但这通常需要一定数量的代码来提交错误信息,各种控制结构放置在HTML文件里。
  80. 创建简单表单验证,代码通常会非常凌乱而效能地下。</p>
  81. <dfn>CodeIgniter提供了一个全面的解决框架,真正的精简你需要写的代码数量。当然也可以从你的HTML表单中分离出控制结构,使得它成为干净而灵活的代码。</dfn>
  82. <h2>预览</h2>
  83. <p>为了能使用CodeIgniter的表单验证功能,你需要做以下三件事情:</p>
  84. <ol>
  85. <li>一个包含表单的 <a href="../general/views.html">视图</a> 文件。</li>
  86. <li>一个包含提交“成功”信息的视图文件。</li>
  87. <li>一个<a href="../general/controllers.html">控制器</a>函数,用来接受和处理提交的数据。</li>
  88. </ol>
  89. <p>让我们创建这三个事件,使用注册表单作为样例:</p>
  90. <h2>表单页</h2>
  91. <p>使用一个文本编辑器,创建一个名叫<dfn>myform.php</dfn>的文件。在文中写入如下代码并保存到<samp>applications/views/</samp>
  92. 文件夹下:</p>
  93. <textarea class="textarea" style="width:100%" cols="50" rows="30">
  94. &lt;html&gt;
  95. &lt;head&gt;
  96. &lt;title&gt;My Form&lt;/title&gt;
  97. &lt;/head&gt;
  98. &lt;body&gt;
  99. &lt;?php echo $this-&gt;validation-&gt;error_string; ?&gt;
  100. &lt;?php echo form_open('form'); ?&gt;
  101. <h5>Username</h5>
  102. &lt;input type="text" name="username" value="" size="50" />
  103. <h5>Password</h5>
  104. &lt;input type="text" name="password" value="" size="50" />
  105. <h5>Password Confirm</h5>
  106. &lt;input type="text" name="passconf" value="" size="50" />
  107. <h5>Email Address</h5>
  108. &lt;input type="text" name="email" value="" size="50" />
  109. <div>&lt;input type="submit" value="Submit" /></div>
  110. &lt;/form&gt;
  111. &lt;/body&gt;
  112. &lt;/html&gt;
  113. </textarea>
  114. <h2>成功页</h2>
  115. <p>使用一个文本编辑器,创建一个名叫 <dfn>formsuccess.php</dfn>的文件。在文中写入如下代码并保存到<samp>applications/views/</samp>
  116. 文件夹下:</p>
  117. <textarea class="textarea" style="width:100%" cols="50" rows="14">
  118. &lt;html&gt;
  119. &lt;head&gt;
  120. &lt;title&gt;My Form&lt;/title&gt;
  121. &lt;/head&gt;
  122. &lt;body&gt;
  123. <h3>Your form was successfully submitted!</h3>
  124. &lt;p>&lt;?php echo anchor('form', 'Try it again!'); ?&gt;&lt;/p>
  125. &lt;/body&gt;
  126. &lt;/html&gt;
  127. </textarea>
  128. <h2>控制器页</h2>
  129. <p>使用一个文本编辑器,创建一个名叫 <dfn>form.php</dfn>的文件。在文中写入如下代码并保存到<samp>applications/controllers/</samp>
  130. 文件夹下:</p>
  131. <textarea class="textarea" style="width:100%" cols="50" rows="21">
  132. &lt;?php
  133. class Form extends Controller &#123;
  134. function index()
  135. &#123;
  136. $this-&gt;load-&gt;helper(array('form', 'url'));
  137. $this-&gt;load-&gt;library('validation');
  138. if ($this-&gt;validation-&gt;run() == FALSE)
  139. &#123;
  140. $this-&gt;load-&gt;view('myform');
  141. &#125;
  142. else
  143. &#123;
  144. $this-&gt;load-&gt;view('formsuccess');
  145. &#125;
  146. &#125;
  147. &#125;
  148. ?&gt;
  149. </textarea>
  150. <h2>试一试!</h2>
  151. <p>用与下面相似的URL地址测试下你的表单:</p>
  152. <code>example.com/index.php/<var>form</var>/</code>
  153. <p><strong>如果你提交了表单,你会发现表单重载了。那是因为你还没有设置任何验证条件,这就是我们接下来要做的。</strong></p>
  154. <h2>说明:</h2>
  155. <p>你会注意到一些关于上面页面的事情:</p>
  156. <p>那个 <dfn>页面</dfn> (myform.php) 是一个除了两个例外的标准页面:</p>
  157. <ol>
  158. <li>它使用一个<dfn>表单助手</dfn> 来创建表单to create the form opening.
  159. 从技术上讲,这是没有必要的。你可以用标准的HTML来创建表单。然而,使用这个助手的好处在于:
  160. 它为你生成了一个段URL,就是你在CONFIG文件里定义的那个。这使得你的程序在修改时可以更简单和灵活。</li>
  161. <li>在表单的顶部,你会注意到一下的不同点:
  162. <code>&lt;?php echo $this-&gt;validation-&gt;error_string; ?&gt;</code>
  163. <p>验证类会使用这个变量返回并显示一些错误信息。如果没有信息将没有返回值。</p>
  164. </li>
  165. </ol>
  166. <p>这个<dfn>控制器</dfn> (form.php) 有一个函数: <dfn>index()</dfn>. 这个函数初始化验证类并加载你的视图文件需要使用的 <var>form helper</var> 和 <var>URL helper</var> 。 当然也 <samp>运行</samp>
  167. 验证过程。这取决于验证是否成功,既不显示表单也没有返回成功信息。</p>
  168. <p><strong>如果还没有告诉验证类使之生效的信息,它会一直返回“FALSE”(布尔值 FALSE)作为默认值。如果数据成功地接受你的条件并且它们没有任何错误,那么<samp>run()</samp>
  169. 函数值返回“TRUE”。</strong></p>
  170. <h2>设置验证条件</h2>
  171. <p>CodeIgniter可以让你设置任意数量的条件来控制给定的范围,循环,甚至同时它可以让你准备并预处理数据。让我们先看看它的用法,我们后面再具体解释。</p>
  172. <p>在你的<dfn>控制器</dfn> (form.php)里, 仅加入下面的初始化函数:</p>
  173. <code>$rules['username'] = "required";<br />
  174. $rules['password'] = "required";<br />
  175. $rules['passconf'] = "required";<br />
  176. $rules['email'] = "required";<br />
  177. <br />
  178. $this-&gt;validation-&gt;set_rules($rules);</code>
  179. <p>你的控制器现在看起来像下面这样:</p>
  180. <textarea class="textarea" style="width:100%" cols="50" rows="28">
  181. &lt;?php
  182. class Form extends Controller &#123;
  183. function index()
  184. &#123;
  185. $this-&gt;load-&gt;helper(array('form', 'url'));
  186. $this-&gt;load-&gt;library('validation');
  187. $rules['username'] = "required";
  188. $rules['password'] = "required";
  189. $rules['passconf'] = "required";
  190. $rules['email'] = "required";
  191. $this-&gt;validation-&gt;set_rules($rules);
  192. if ($this-&gt;validation-&gt;run() == FALSE)
  193. &#123;
  194. $this-&gt;load-&gt;view('myform');
  195. &#125;
  196. else
  197. &#123;
  198. $this-&gt;load-&gt;view('formsuccess');
  199. &#125;
  200. &#125;
  201. &#125;
  202. ?&gt;
  203. </textarea>
  204. <p><dfn>现在提交空白的表单,你将会看到错误信息。如果你提交的表单包含有完全正确的信息,你将看到你的成功页。</dfn></p>
  205. <p class="important"><strong>注意:</strong> 当表单数据有错误时,它不会被重新填充。当我们讲明验证规则后,马上回来解释它。</p>
  206. <h2>改变出错信息的样式</h2>
  207. <p>默认情况下,系统会为每个错误提示信息添加一个段落的标识(&lt;p>)。你可以很容易地通过编码去改变这些界定符号,在控制器里写入一下代码:</p>
  208. <code>$this-&gt;validation-&gt;set_error_delimiters('<kbd>&lt;div class="error"></kbd>', '<kbd>&lt;/div></kbd>');</code>
  209. <p>在这个例子中,我们将其改成了 div 标签。</p>
  210. <h2>顺序编排规则</h2>
  211. <p>CodeIgniter可以让你把所有的验证条件有序地串联起来。我们来试一下。把你的验证条件数据改成下面的样子:</p>
  212. <code>$rules['username'] = "required|min_length[5]|max_length[12]";<br />
  213. $rules['password'] = "required|matches[passconf]";<br />
  214. $rules['passconf'] = "required";<br />
  215. $rules['email'] = "required|valid_email";</code>
  216. <p>以上代码要求如下:</p>
  217. <ol>
  218. <li>username区域要求在5位到12位之间.</li>
  219. <li>password 区域必须和 password confirmation 区域匹配.</li>
  220. <li>Email 区域 必须包含一个合法的Email地址.</li>
  221. </ol>
  222. <p>尽管尝试下吧!</p>
  223. <p class="important"><strong>请注意:</strong> 如果你阅读最后的“规则参考”(Rule Reference),你会发现有很多可用的规则!</p>
  224. <h2>准备数据</h2>
  225. <p>在验证函数的基础上,你可以使用不同的方法准备好你的数据,例如,你可以建立这样的规则:</p>
  226. <code>$rules['username'] = "<kbd>trim</kbd>|required|min_length[5]|max_length[12]|<kbd>xss_clean</kbd>";<br />
  227. $rules['password'] = "<kbd>trim</kbd>|required|matches[passconf]|<kbd>md5</kbd>";<br />
  228. $rules['passconf'] = "<kbd>trim</kbd>|required";<br />
  229. $rules['email'] = "<kbd>trim</kbd>|required|valid_email";</code>
  230. <p>上面的例子中,我们“修剪”内容,转换密码区域为 MD5 编码,通过“XSS_CLEAN”函数检测用户名,移除危险的数据。</p>
  231. <p class="important"><strong>默认的PHP函数能为一个规则使用一个参数,像 <dfn>htmlspecialchars</dfn>,
  232. <dfn>trim</dfn>, <dfn>MD5</dfn>, 等等.</strong></p>
  233. <p><strong>Note:</strong> You will generally want to use the prepping functions <strong>after</strong>
  234. the validation rules so if there is an error, the original data will be shown in the form.</p>
  235. <h2>回调函数:你自己的验证函数</h2>
  236. <p>验证系统支持回调你自己的验证函数. 这允许你通过扩展验证类来适应自己的需要. 例如, 如果你需要执行一个数据库查询来查看用户是否选择了唯一的用户名,你可以通过创建一个回调函数来做这件事. 让我们创建一个简单的例子.</p>
  237. <p>在你的控制器中将username规则改为:</p>
  238. <code>$rules['username'] = "callback_username_check"; </code>
  239. <p>然后在你的控制器中添加一个新的函数叫做 <dfn>username_check</dfn> . 你的控制器看起来应该像下面的例子:</p>
  240. <textarea class="textarea" style="width:100%" cols="50" rows="44">
  241. &lt;?php
  242. class Form extends Controller &#123;
  243. function index()
  244. &#123;
  245. $this-&gt;load-&gt;helper(array('form', 'url'));
  246. $this-&gt;load-&gt;library('validation');
  247. $rules['username'] = "callback_username_check";
  248. $rules['password'] = "required";
  249. $rules['passconf'] = "required";
  250. $rules['email'] = "required";
  251. $this-&gt;validation-&gt;set_rules($rules);
  252. if ($this-&gt;validation-&gt;run() == FALSE)
  253. &#123;
  254. $this-&gt;load-&gt;view('myform');
  255. &#125;
  256. else
  257. &#123;
  258. $this-&gt;load-&gt;view('formsuccess');
  259. &#125;
  260. &#125;
  261. function username_check($str)
  262. &#123;
  263. if ($str == 'test')
  264. &#123;
  265. $this-&gt;validation-&gt;set_message('username_check', 'The %s field can not be the word "test"');
  266. return FALSE;
  267. &#125;
  268. else
  269. &#123;
  270. return TRUE;
  271. &#125;
  272. &#125;
  273. &#125;
  274. ?&gt;
  275. </textarea>
  276. <p>重新载入表单并以"test"做为用户名提交. 你可以看到表单中的数据已经发送到你的回调函数中处理.</p>
  277. <p><strong>要想回调一个函数只需在你定义的函数名前加上一个"callback_"前缀即可.</strong></p>
  278. <p>错误消息可以使用 <dfn>$this-&gt;validation-&gt;set_message</dfn> 函数来设置.
  279. 请牢记消息键(第一个参数)必须与您的函数名相匹配.</p>
  280. <p class="important"><strong>注意:</strong> 你可以在任何规则中使用你自定义的错误消息, 只需设置类似的消息. 例如,为"required"规则改变消息你可以这样做:</p>
  281. <code>$this-&gt;validation-&gt;set_message('required', 'Your custom message here');</code>
  282. <h2>填充表单</h2>
  283. <p>我们花了不少时间处理错误。现在是讨论使用数据重新填充表单的时候了。这里的做法和你的验证规则类似。在你的验证规则下面加入如下代码:</p>
  284. <code>$fields['username'] = 'Username';<br />
  285. $fields['password'] = 'Password';<br />
  286. $fields['passconf'] = 'Password Confirmation';<br />
  287. $fields['email'] = 'Email Address';<br />
  288. <br />
  289. $this-&gt;validation-&gt;set_fields($fields);</code>
  290. <p>数组的关键字实际上是表单域的名字,对应的值是你想要在错误信息中显示的全名。</p>
  291. <p>现在你控制器中的index函数看起来应该像这样:</p>
  292. <textarea class="textarea" style="width:100%" cols="50" rows="30">
  293. function index()
  294. &#123;
  295. $this-&gt;load-&gt;helper(array('form', 'url'));
  296. $this-&gt;load-&gt;library('validation');
  297. $rules['username'] = "required";
  298. $rules['password'] = "required";
  299. $rules['passconf'] = "required";
  300. $rules['email'] = "required";
  301. $this-&gt;validation-&gt;set_rules($rules);
  302. $fields['username'] = 'Username';
  303. $fields['password'] = 'Password';
  304. $fields['passconf'] = 'Password Confirmation';
  305. $fields['email'] = 'Email Address';
  306. $this-&gt;validation-&gt;set_fields($fields);
  307. if ($this-&gt;validation-&gt;run() == FALSE)
  308. &#123;
  309. $this-&gt;load-&gt;view('myform');
  310. &#125;
  311. else
  312. &#123;
  313. $this-&gt;load-&gt;view('formsuccess');
  314. &#125;
  315. &#125;
  316. </textarea>
  317. <p>现在打开你的视图文件<dfn>myform.php</dfn>,根据每个表单域的名字更新它们的值。</p>
  318. <textarea class="textarea" style="width:100%" cols="50" rows="30">
  319. &lt;html&gt;
  320. &lt;head&gt;
  321. &lt;title&gt;My Form&lt;/title&gt;
  322. &lt;/head&gt;
  323. &lt;body&gt;
  324. &lt;?=$this-&gt;validation-&gt;error_string; ?&gt;
  325. &lt;?php echo form_open('form'); ?&gt;
  326. <h5>Username</h5>
  327. &lt;input type="text" name="username" value="&lt;?php echo $this-&gt;validation-&gt;username;?&gt;" size="50" />
  328. <h5>Password</h5>
  329. &lt;input type="text" name="password" value="&lt;?php echo $this-&gt;validation-&gt;password;?&gt;" size="50" />
  330. <h5>Password Confirm</h5>
  331. &lt;input type="text" name="passconf" value="&lt;?php echo $this-&gt;validation-&gt;passconf;?&gt;" size="50" />
  332. <h5>Email Address</h5>
  333. &lt;input type="text" name="email" value="&lt;?php echo $this-&gt;validation-&gt;email;?&gt;" size="50" />
  334. <div>&lt;input type="submit" value="Submit" /></div>
  335. &lt;/form&gt;
  336. &lt;/body&gt;
  337. &lt;/html&gt;
  338. </textarea>
  339. <p>现在重新加载你的页面,提交表单并触发一个错误。你的表单将会被重新填充而且错误信息也会包含更多相关的表单域的名字。</p>
  340. <h2>单独显示错误</h2>
  341. <p>如果你想要在每个表单域旁显示错误,而不是显示一个错误列表,你可以像这样修改你的表单:</p>
  342. <textarea class="textarea" style="width:100%" cols="50" rows="20">
  343. <h5>Username</h5>
  344. &lt;?php echo $this-&gt;validation-&gt;username_error; ?&gt;
  345. &lt;input type="text" name="username" value="&lt;?php echo $this-&gt;validation-&gt;username;?&gt;" size="50" />
  346. <h5>Password</h5>
  347. &lt;?php echo $this-&gt;validation-&gt;password_error; ?&gt;
  348. &lt;input type="text" name="password" value="&lt;?php echo $this-&gt;validation-&gt;password;?&gt;" size="50" />
  349. <h5>Password Confirm</h5>
  350. &lt;?php echo $this-&gt;validation-&gt;passconf_error; ?&gt;
  351. &lt;input type="text" name="passconf" value="&lt;?php echo $this-&gt;validation-&gt;passconf;?&gt;" size="50" />
  352. <h5>Email Address</h5>
  353. &lt;?php echo $this-&gt;validation-&gt;email_error; ?&gt;
  354. &lt;input type="text" name="email" value="&lt;?php echo $this-&gt;validation-&gt;email;?&gt;" size="50" /></textarea>
  355. <p>如果没有错误,不会显示任何东西。如果有错误发生,消息将会使用你设置的分割标记显示(&lt;p> 标记是默认值)。</p>
  356. <p class="important"><strong>Note: </strong>要这样显示错误信息,你必须之前使用<kbd>$this-&gt;validation-&gt;set_fields</kbd>
  357. 函数描述。错误将会被转换成表单域名加"_error"后缀的变量。例如,你的用户名错误的值可以这样访问:<br /><dfn>$this-&gt;validation-&gt;username_error</dfn>.</p>
  358. <h2>规则参考</h2>
  359. <p>下面是可用的原生规则列表:</p>
  360. <table cellpadding="0" cellspacing="1" border="0" style="width:100%" class="tableborder">
  361. <tr>
  362. <th>Rule</th>
  363. <th>Parameter</th>
  364. <th>Description</th>
  365. <th>Example</th>
  366. </tr><tr>
  367. <td class="td"><strong>required</strong></td>
  368. <td class="td">No</td>
  369. <td class="td">Returns FALSE if the form element is empty.</td>
  370. <td class="td"> </td>
  371. </tr><tr>
  372. <td class="td"><strong>matches</strong></td>
  373. <td class="td">Yes</td>
  374. <td class="td">Returns FALSE if the form element does not match the one in the parameter.</td>
  375. <td class="td">matches[form_item]</td>
  376. </tr><tr>
  377. <td class="td"><strong>min_length</strong></td>
  378. <td class="td">Yes</td>
  379. <td class="td">Returns FALSE if the form element is shorter then the parameter value.</td>
  380. <td class="td">min_length[6]</td>
  381. </tr><tr>
  382. <td class="td"><strong>max_length</strong></td>
  383. <td class="td">Yes</td>
  384. <td class="td">Returns FALSE if the form element is longer then the parameter value.</td>
  385. <td class="td">max_length[12]</td>
  386. </tr><tr>
  387. <td class="td"><strong>exact_length</strong></td>
  388. <td class="td">Yes</td>
  389. <td class="td">Returns FALSE if the form element is not exactly the parameter value.</td>
  390. <td class="td">exact_length[8]</td>
  391. </tr><tr>
  392. <td class="td"><strong>alpha</strong></td>
  393. <td class="td">No</td>
  394. <td class="td">Returns FALSE if the form element contains anything other than alphabetical characters.</td>
  395. <td class="td"> </td>
  396. </tr><tr>
  397. <td class="td"><strong>alpha_numeric</strong></td>
  398. <td class="td">No</td>
  399. <td class="td">Returns FALSE if the form element contains anything other than alpha-numeric characters.</td>
  400. <td class="td"> </td>
  401. </tr><tr>
  402. <td class="td"><strong>alpha_dash</strong></td>
  403. <td class="td">No</td>
  404. <td class="td">Returns FALSE if the form element contains anything other than alpha-numeric characters, underscores or dashes.</td>
  405. <td class="td"> </td>
  406. </tr>
  407. <tr>
  408. <td class="td"><strong>numeric</strong></td>
  409. <td class="td">No</td>
  410. <td class="td">Returns FALSE if the form element contains anything other than numeric characters.</td>
  411. <td class="td">&nbsp;</td>
  412. </tr>
  413. <tr>
  414. <td class="td"><strong>integer</strong></td>
  415. <td class="td">No</td>
  416. <td class="td">Returns FALSE if the form element contains anything other than an integer.</td>
  417. <td class="td">&nbsp;</td>
  418. </tr><tr>
  419. <td class="td"><strong>valid_email</strong></td>
  420. <td class="td">No</td>
  421. <td class="td">Returns FALSE if the form element does not contain a valid email address.</td>
  422. <td class="td">&nbsp;</td>
  423. </tr>
  424. <tr>
  425. <td class="td"><strong>is_natural</strong></td>
  426. <td class="td">No</td>
  427. <td class="td">如果为非整数(自然数) 则 Returns FALSE (注意 CI 1.7x版 新增, CI 1.6x不能使用该验证规则)</td>
  428. <td class="td">&nbsp;</td>
  429. </tr>
  430. <tr>
  431. <td class="td"><strong>is_natural_no_zero</strong></td>
  432. <td class="td">No</td>
  433. <td class="td">如果为非正整数(自然数) 则 Returns FALSE (注意 CI 1.7x版 新增, CI 1.6x不能使用该验证规则)</td>
  434. <td class="td">&nbsp;</td>
  435. </tr>
  436. <tr>
  437. <td class="td"><strong>valid_ip</strong></td>
  438. <td class="td">No</td>
  439. <td class="td">Returns FALSE if the supplied IP is not valid.</td>
  440. <td class="td">&nbsp;</td>
  441. </tr>
  442. <tr>
  443. <td class="td"><strong>valid_base64</strong></td>
  444. <td class="td">No</td>
  445. <td class="td">Returns FALSE if the supplied string contains anything other than valid Base64 characters.</td>
  446. <td class="td">&nbsp;</td>
  447. </tr>
  448. </table>
  449. <p><strong>Note:</strong> 这些规则也可以像独立的函数一样被调用。例如:</p>
  450. <code>$this-&gt;validation-&gt;required($string);</code>
  451. <p class="important"><strong>Note:</strong> 你也可以使用接受一个参数的PHP原生函数。</p>
  452. <h2>Prepping Reference</h2>
  453. <p>下面是所有可用的预处理函数列表</p>
  454. <table cellpadding="0" cellspacing="1" border="0" style="width:100%" class="tableborder">
  455. <tr>
  456. <th>Name</th>
  457. <th>Parameter</th>
  458. <th>Description</th>
  459. </tr><tr>
  460. <td class="td"><strong>xss_clean</strong></td>
  461. <td class="td">No</td>
  462. <td class="td">Runs the data through the XSS filtering function, described in the <a href="input.html">Input Class</a> page.</td>
  463. </tr><tr>
  464. <td class="td"><strong>prep_for_form</strong></td>
  465. <td class="td">No</td>
  466. <td class="td">Converts special characters so that HTML data can be shown in a form field without breaking it.</td>
  467. </tr><tr>
  468. <td class="td"><strong>prep_url</strong></td>
  469. <td class="td">No</td>
  470. <td class="td">Adds "http://" to URLs if missing.</td>
  471. </tr><tr>
  472. <td class="td"><strong>strip_image_tags</strong></td>
  473. <td class="td">No</td>
  474. <td class="td">Strips the HTML from image tags leaving the raw URL.</td>
  475. </tr><tr>
  476. <td class="td"><strong>encode_php_tags</strong></td>
  477. <td class="td">No</td>
  478. <td class="td">Converts PHP tags to entities.</td>
  479. </tr>
  480. </table>
  481. <p class="important"><strong>Note:</strong> 你也可以,使用接收一个参数的PHP原生函数,例如<kbd>trim</kbd>, <kbd>htmlspecialchars</kbd>, <kbd>urldecode</kbd>,等等。</p>
  482. <h2>设置自定义错误信息</h2>
  483. <p>所有的原生错误信息防止在下面的语言文件中:<dfn>language/english/validation_lang.php</dfn></p>
  484. <p>你可以编辑这个文件,或使用如下函数设置你自己的信息。</p>
  485. <code>$this-&gt;validation-&gt;set_message('<var>rule</var>', '<var>Error Message</var>');</code>
  486. <p><var>rule</var>是特定规则的名字,<var>Error Message</var>是你想要显示的信息。</p>
  487. <h2>处理选择菜单,单选按钮,和复选框</h2>
  488. <p>如果你使用了选择菜单,单选按钮,和复选框,你会想在出错时保持原先的选择。验证类有三个函数帮助你完成这些:</p>
  489. <h2>set_select()</h2>
  490. <p>允许你显示和提交时状态一致的菜单项。第一个参数是选择菜单的名字,第二个参数必须包含每个选项的值。例如:</p>
  491. <code>
  492. &lt;select name="myselect"><br />
  493. &lt;option value="one" <dfn>&lt;?php echo $this-&gt;validation-&gt;set_select('myselect', 'one'); ?&gt;</dfn> >One&lt;/option><br />
  494. &lt;option value="two" <dfn>&lt;?php echo $this-&gt;validation-&gt;set_select('myselect', 'two'); ?&gt;</dfn> >Two&lt;/option><br />
  495. &lt;option value="three" <dfn>&lt;?php echo $this-&gt;validation-&gt;set_select('myselect', 'three'); ?&gt;</dfn> >Three&lt;/option><br />
  496. &lt;/select>
  497. </code>
  498. <h2>set_checkbox()</h2>
  499. <p>允许你显示和提交时状态一致的复选框。第一个参数是复选框的名字,第二个参数必须包含它的值,例如:</p>
  500. <code>&lt;input type="checkbox" name="mycheck" value="1" <dfn>&lt;?php echo $this-&gt;validation-&gt;set_checkbox('mycheck', '1'); ?&gt;</dfn> /></code>
  501. <h2>set_radio()</h2>
  502. <p>允许你显示和提交时状态一致的单选按钮。第一个参数是单选按钮的名字,第二个参数必须包含它的值:例如:</p>
  503. <code>&lt;input type="radio" name="myradio" value="1" <dfn>&lt;?php echo $this-&gt;validation-&gt;set_radio('myradio', '1'); ?&gt;</dfn> /></code><p>&nbsp;</p>
  504. <div id="Contributors">
  505. 翻译贡献者:
  506. Hex, lishen2, lomatus, shnwqshnwq, tanqimin, wjm7301, yz20sui</div>
  507. <div id="DocDate">
  508. 最后修改: 2009-09-12 15:36:46</div>
  509. </div>
  510. <!-- END CONTENT -->
  511. <div id="footer">
  512. <p>
  513. 上一个主题:&nbsp;&nbsp;<a href="user_agent.html">User-Agent 类</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  514. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="xmlrpc.html">XML-RPC 类</a> </p>
  515. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  516. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  517. </div>
  518. </body>
  519. </html>