admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 1 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
| 2 | <html>
|
| 3 | <head>
|
| 4 |
|
Derek Allard | 404e35d | 2007-08-07 01:00:45 +0000 | [diff] [blame] | 5 | <title>CodeIgniter User Guide : Form Validation</title>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 6 |
|
| 7 | <style type='text/css' media='all'>@import url('../userguide.css');</style>
|
| 8 | <link rel='stylesheet' type='text/css' media='all' href='../userguide.css' />
|
| 9 |
|
admin | 17a890d | 2006-09-27 20:42:42 +0000 | [diff] [blame] | 10 | <script type="text/javascript" src="../nav/nav.js"></script>
|
admin | 2296fc3 | 2006-09-27 21:07:02 +0000 | [diff] [blame] | 11 | <script type="text/javascript" src="../nav/prototype.lite.js"></script>
|
admin | 17a890d | 2006-09-27 20:42:42 +0000 | [diff] [blame] | 12 | <script type="text/javascript" src="../nav/moo.fx.js"></script>
|
Derek Allard | b341237 | 2007-10-25 12:15:16 +0000 | [diff] [blame] | 13 | <script type="text/javascript" src="../nav/user_guide_menu.js"></script>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 14 |
|
| 15 | <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
| 16 | <meta http-equiv='expires' content='-1' />
|
| 17 | <meta http-equiv= 'pragma' content='no-cache' />
|
| 18 | <meta name='robots' content='all' />
|
Derek Allard | 3d879d5 | 2008-01-18 19:41:32 +0000 | [diff] [blame] | 19 | <meta name='author' content='ExpressionEngine Dev Team' />
|
Derek Allard | d2df9bc | 2007-04-15 17:41:17 +0000 | [diff] [blame] | 20 | <meta name='description' content='CodeIgniter User Guide' />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 21 |
|
| 22 | </head>
|
| 23 | <body>
|
| 24 |
|
| 25 | <!-- START NAVIGATION -->
|
| 26 | <div id="nav"><div id="nav_inner"><script type="text/javascript">create_menu('../');</script></div></div>
|
| 27 | <div id="nav2"><a name="top"></a><a href="javascript:void(0);" onclick="myHeight.toggle();"><img src="../images/nav_toggle.jpg" width="153" height="44" border="0" title="Toggle Table of Contents" alt="Toggle Table of Contents" /></a></div>
|
| 28 | <div id="masthead">
|
| 29 | <table cellpadding="0" cellspacing="0" border="0" style="width:100%">
|
| 30 | <tr>
|
Derek Allard | 39b622d | 2008-01-16 21:10:09 +0000 | [diff] [blame] | 31 | <td><h1>CodeIgniter User Guide Version 1.6.0</h1></td>
|
admin | c0d5d52 | 2006-10-30 19:40:35 +0000 | [diff] [blame] | 32 | <td id="breadcrumb_right"><a href="../toc.html">Table of Contents Page</a></td>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 33 | </tr>
|
| 34 | </table>
|
| 35 | </div>
|
| 36 | <!-- END NAVIGATION -->
|
| 37 |
|
| 38 |
|
| 39 | <!-- START BREADCRUMB -->
|
| 40 | <table cellpadding="0" cellspacing="0" border="0" style="width:100%">
|
| 41 | <tr>
|
| 42 | <td id="breadcrumb">
|
Derek Allard | d2df9bc | 2007-04-15 17:41:17 +0000 | [diff] [blame] | 43 | <a href="http://www.codeigniter.com/">CodeIgniter Home</a> ›
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 44 | <a href="../index.html">User Guide Home</a> ›
|
| 45 | Form Validation
|
| 46 | </td>
|
Derek Allard | bc03091 | 2007-06-24 18:25:29 +0000 | [diff] [blame] | 47 | <td id="searchbox"><form method="get" action="http://www.google.com/search"><input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.com/user_guide/" />Search User Guide <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" /> <input type="submit" class="submit" name="sa" value="Go" /></form></td>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 48 | </tr>
|
| 49 | </table>
|
| 50 | <!-- END BREADCRUMB -->
|
| 51 |
|
| 52 | <br clear="all" />
|
| 53 |
|
| 54 |
|
| 55 | <!-- START CONTENT -->
|
| 56 | <div id="content">
|
| 57 |
|
| 58 | <h1>Form Validation</h1>
|
| 59 |
|
Derek Allard | d2df9bc | 2007-04-15 17:41:17 +0000 | [diff] [blame] | 60 | <p>Before explaining CodeIgniter's approach to data validation, let's describe the ideal scenario:</p>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 61 |
|
| 62 | <ol>
|
| 63 | <li>A form is displayed.</li>
|
| 64 | <li>You fill it in and submit it.</li>
|
| 65 | <li>If you submitted something invalid, or perhaps missed a required item, the form is redisplayed containing your data along with an error message describing the problem.</li>
|
| 66 | <li>This process continues until you have submitted a valid form.</li>
|
| 67 | </ol>
|
| 68 |
|
| 69 | <p>On the receiving end, the script must:</p>
|
| 70 |
|
| 71 | <ol>
|
| 72 | <li>Check for required data.</li>
|
admin | e334c47 | 2006-10-21 19:44:22 +0000 | [diff] [blame] | 73 | <li>Verify that the data is of the correct type, and meets the correct criteria. (For example, if a username is submitted
|
| 74 | it must be validated to contain only permitted characters. It must be of a minimum length,
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 75 | and not exceed a maximum length. The username can't be someone else's existing username, or perhaps even a reserved word. Etc.)</li>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 76 | <li>Sanitize the data for security.</li>
|
| 77 | <li>Pre-format the data if needed (Does the data need to be trimmed? HTML encoded? Etc.)</li>
|
| 78 | <li>Prep the data for insertion in the database.</li>
|
| 79 | </ol>
|
| 80 |
|
| 81 |
|
| 82 | <p>Although there is nothing complex about the above process, it usually requires a significant
|
| 83 | amount of code, and to display error messages, various control structures are usually placed within the form HTML.
|
| 84 | Form validation, while simple to create, is generally very messy and tedious to implement.</p>
|
| 85 |
|
Derek Allard | d2df9bc | 2007-04-15 17:41:17 +0000 | [diff] [blame] | 86 | <dfn>CodeIgniter provides a comprehensive validation framework that truly minimizes the amount of code you'll write.
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 87 | It also removes all control structures from your form HTML, permitting it to be clean and free of code.</dfn>
|
| 88 |
|
| 89 | <h2>Overview</h2>
|
| 90 |
|
Derek Allard | d2df9bc | 2007-04-15 17:41:17 +0000 | [diff] [blame] | 91 | <p>In order to implement CodeIgniter's form validation you'll need three things:</p>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 92 |
|
| 93 | <ol>
|
| 94 | <li>A <a href="../general/views.html">View</a> file containing the form.</li>
|
| 95 | <li>A View file containing a "success" message to be displayed upon successful submission.</li>
|
| 96 | <li>A <a href="../general/controllers.html">controller</a> function to receive and process the submitted data.</li>
|
| 97 | </ol>
|
| 98 |
|
| 99 | <p>Let's create those three things, using a member sign-up form as the example.</p>
|
| 100 |
|
| 101 | <h2>The Form</h2>
|
| 102 |
|
| 103 | <p>Using a text editor, create a form called <dfn>myform.php</dfn>. In it, place this code and save it to your <samp>applications/views/</samp>
|
| 104 | folder:</p>
|
| 105 |
|
| 106 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 107 | <textarea class="textarea" style="width:100%" cols="50" rows="30"><html>
|
| 108 | <head>
|
| 109 | <title>My Form</title>
|
| 110 | </head>
|
| 111 | <body>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 112 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 113 | <?=$this->validation->error_string; ?>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 114 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 115 | <?=form_open('form'); ?>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 116 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 117 | <h5>Username</h5>
|
| 118 | <input type="text" name="username" value="" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 119 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 120 | <h5>Password</h5>
|
| 121 | <input type="text" name="password" value="" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 122 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 123 | <h5>Password Confirm</h5>
|
| 124 | <input type="text" name="passconf" value="" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 125 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 126 | <h5>Email Address</h5>
|
| 127 | <input type="text" name="email" value="" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 128 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 129 | <div><input type="submit" value="Submit" /></div>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 130 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 131 | </form>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 132 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 133 | </body>
|
| 134 | </html>
|
| 135 | </textarea>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 136 |
|
| 137 |
|
| 138 | <h2>The Success Page</h2>
|
| 139 |
|
| 140 |
|
| 141 | <p>Using a text editor, create a form called <dfn>formsuccess.php</dfn>. In it, place this code and save it to your <samp>applications/views/</samp>
|
| 142 | folder:</p>
|
| 143 |
|
| 144 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 145 | <textarea class="textarea" style="width:100%" cols="50" rows="14">
|
| 146 | <html>
|
| 147 | <head>
|
| 148 | <title>My Form</title>
|
| 149 | </head>
|
| 150 | <body>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 151 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 152 | <h3>Your form was successfully submitted!</h3>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 153 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 154 | <p><?=anchor('form', 'Try it again!'); ?></p>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 155 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 156 | </body>
|
| 157 | </html>
|
| 158 | </textarea>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 159 |
|
| 160 |
|
| 161 | <h2>The Controller</h2>
|
| 162 |
|
| 163 | <p>Using a text editor, create a controller called <dfn>form.php</dfn>. In it, place this code and save it to your <samp>applications/controllers/</samp>
|
| 164 | folder:</p>
|
| 165 |
|
| 166 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 167 | <textarea class="textarea" style="width:100%" cols="50" rows="21"><?php
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 168 |
|
| 169 | class Form extends Controller {
|
| 170 |
|
| 171 | function index()
|
| 172 | {
|
| 173 | $this->load->helper(array('form', 'url'));
|
| 174 |
|
| 175 | $this->load->library('validation');
|
| 176 |
|
| 177 | if ($this->validation->run() == FALSE)
|
| 178 | {
|
| 179 | $this->load->view('myform');
|
| 180 | }
|
| 181 | else
|
| 182 | {
|
| 183 | $this->load->view('formsuccess');
|
| 184 | }
|
| 185 | }
|
| 186 | }
|
| 187 | ?></textarea>
|
| 188 |
|
| 189 |
|
| 190 | <h2>Try it!</h2>
|
| 191 |
|
| 192 | <p>To try your form, visit your site using a URL similar to this one:</p>
|
| 193 |
|
| 194 | <code>www.your-site.com/index.php/<var>form</var>/</code>
|
| 195 |
|
admin | e334c47 | 2006-10-21 19:44:22 +0000 | [diff] [blame] | 196 | <p><strong>If you submit the form you should simply see the form reload. That's because you haven't set up any validation
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 197 | rules yet, which we'll get to in a moment.</strong></p>
|
| 198 |
|
| 199 |
|
| 200 | <h2>Explanation</h2>
|
| 201 |
|
| 202 | <p>You'll notice several things about the above pages:</p>
|
| 203 |
|
| 204 | <p>The <dfn>form</dfn> (myform.php) is a standard web form with a couple exceptions:</p>
|
| 205 |
|
| 206 | <ol>
|
| 207 | <li>It uses a <dfn>form helper</dfn> to create the form opening.
|
| 208 | Technically, this isn't necessary. You could create the form using standard HTML. However, the benefit of using the helper
|
| 209 | is that it generates the action URL for you, based on the URL in your config file. This makes your application more portable
|
| 210 | and flexible in the event your URLs change.</li>
|
| 211 |
|
| 212 | <li>At the top of the form you'll notice the following variable:
|
| 213 | <code><?=$this->validation->error_string; ?></code>
|
| 214 |
|
| 215 | <p>This variable will display any error messages sent back by the validator. If there are no messages it returns nothing.</p>
|
| 216 | </li>
|
| 217 | </ol>
|
| 218 |
|
| 219 | <p>The <dfn>controller</dfn> (form.php) has one function: <dfn>index()</dfn>. This function initializes the validation class and
|
admin | e334c47 | 2006-10-21 19:44:22 +0000 | [diff] [blame] | 220 | loads the <var>form helper</var> and <var>URL helper</var> used by your view files. It also <samp>runs</samp>
|
| 221 | the validation routine. Based on
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 222 | whether the validation was successful it either presents the form or the success page.</p>
|
| 223 |
|
| 224 | <p><strong>Since you haven't told the validation class to validate anything yet, it returns "false" (boolean false) by default. The <samp>run()</samp>
|
| 225 | function only returns "true" if it has successfully applied your rules without any of them failing.</strong></p>
|
| 226 |
|
| 227 |
|
| 228 | <h2>Setting Validation Rules</h2>
|
| 229 |
|
Derek Allard | d2df9bc | 2007-04-15 17:41:17 +0000 | [diff] [blame] | 230 | <p>CodeIgniter lets you set as many validation rules as you need for a given field, cascading them in order, and it even lets you prep and pre-process the field data
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 231 | at the same time. Let's see it in action, we'll explain it afterwards.</p>
|
| 232 |
|
| 233 | <p>In your <dfn>controller</dfn> (form.php), add this code just below the validation initialization function:</p>
|
| 234 |
|
| 235 | <code>$rules['username'] = "required";<br />
|
| 236 | $rules['password'] = "required";<br />
|
| 237 | $rules['passconf'] = "required";<br />
|
| 238 | $rules['email'] = "required";<br />
|
| 239 | <br />
|
| 240 | $this->validation->set_rules($rules);</code>
|
| 241 |
|
| 242 | <p>Your controller should now look like this:</p>
|
| 243 |
|
| 244 | <textarea class="textarea" style="width:100%" cols="50" rows="28"><?php
|
| 245 |
|
| 246 | class Form extends Controller {
|
| 247 |
|
| 248 | function index()
|
| 249 | {
|
| 250 | $this->load->helper(array('form', 'url'));
|
| 251 |
|
| 252 | $this->load->library('validation');
|
| 253 |
|
| 254 | $rules['username'] = "required";
|
| 255 | $rules['password'] = "required";
|
| 256 | $rules['passconf'] = "required";
|
| 257 | $rules['email'] = "required";
|
| 258 |
|
| 259 | $this->validation->set_rules($rules);
|
| 260 |
|
| 261 | if ($this->validation->run() == FALSE)
|
| 262 | {
|
| 263 | $this->load->view('myform');
|
| 264 | }
|
| 265 | else
|
| 266 | {
|
| 267 | $this->load->view('formsuccess');
|
| 268 | }
|
| 269 | }
|
| 270 | }
|
| 271 | ?></textarea>
|
| 272 |
|
| 273 | <p><dfn>Now submit the form with the fields blank and you should see the error message.
|
| 274 | If you submit the form with all the fields populated you'll see your success page.</dfn></p>
|
| 275 |
|
| 276 | <p class="important"><strong>Note:</strong> The form fields are not yet being re-populated with the data when
|
| 277 | there is an error. We'll get to that shortly, once we're through explaining the validation rules.</p>
|
| 278 |
|
| 279 |
|
| 280 | <h2>Changing the Error Delimiters</h2>
|
| 281 |
|
| 282 | <p>By default, the system adds a paragraph tag (<p>) around each error message shown. You can easily change these delimiters with
|
| 283 | this code, placed in your controller:</p>
|
| 284 |
|
| 285 | <code>$this->validation->set_error_delimiters('<kbd><div class="error"></kbd>', '<kbd></div></kbd>');</code>
|
| 286 |
|
| 287 | <p>In this example, we've switched to using div tags.</p>
|
| 288 |
|
| 289 | <h2>Cascading Rules</h2>
|
| 290 |
|
Derek Allard | d2df9bc | 2007-04-15 17:41:17 +0000 | [diff] [blame] | 291 | <p>CodeIgniter lets you pipe multiple rules together. Let's try it. Change your rules array like this:</p>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 292 |
|
| 293 |
|
| 294 | <code>$rules['username'] = "required|min_length[5]|max_length[12]";<br />
|
| 295 | $rules['password'] = "required|matches[passconf]";<br />
|
| 296 | $rules['passconf'] = "required";<br />
|
| 297 | $rules['email'] = "required|valid_email";</code>
|
| 298 |
|
| 299 | <p>The above code requires that:</p>
|
| 300 |
|
| 301 | <ol>
|
| 302 | <li>The username field be no shorter than 5 characters and no longer than 12.</li>
|
| 303 | <li>The password field must match the password confirmation field.</li>
|
| 304 | <li>The email field must contain a valid email address.</li>
|
| 305 | </ol>
|
| 306 |
|
| 307 | <p>Give it a try!</p>
|
| 308 |
|
| 309 | <p class="important"><strong>Note:</strong> There are numerous rules available which you can read about in the validation reference.</p>
|
| 310 |
|
| 311 |
|
| 312 | <h2>Prepping Data</h2>
|
| 313 |
|
admin | e334c47 | 2006-10-21 19:44:22 +0000 | [diff] [blame] | 314 | <p>In addition to the validation functions like the ones we used above, you can also prep your data in various ways.
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 315 | For example, you can set up rules like this:</p>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 316 |
|
| 317 | <code>$rules['username'] = "<kbd>trim</kbd>|required|min_length[5]|max_length[12]|<kbd>xss_clean</kbd>";<br />
|
| 318 | $rules['password'] = "<kbd>trim</kbd>|required|matches[passconf]|<kbd>md5</kbd>";<br />
|
| 319 | $rules['passconf'] = "<kbd>trim</kbd>|required";<br />
|
| 320 | $rules['email'] = "<kbd>trim</kbd>|required|valid_email";</code>
|
| 321 |
|
| 322 | <p>In the above, we are "trimming" the fields, converting the password to MD5, and running the username through
|
| 323 | the "xss_clean" function, which removes malicious data.</p>
|
| 324 |
|
| 325 | <p class="important"><strong>Any native PHP function that accepts one parameter can be used as a rule, like <dfn>htmlspecialchars</dfn>,
|
| 326 | <dfn>trim</dfn>, <dfn>MD5</dfn>, etc.</strong></p>
|
| 327 |
|
| 328 | <p><strong>Note:</strong> You will generally want to use the prepping functions <strong>after</strong>
|
| 329 | the validation rules so if there is an error, the original data will be shown in the form.</p>
|
| 330 |
|
| 331 | <h2>Callbacks: Your own Validation Functions</h2>
|
| 332 |
|
| 333 | <p>The validation system supports callbacks to your own validation functions. This permits you to extend the validation class
|
| 334 | to meet your needs. For example, if you need to run a database query to see if the user is choosing a unique username, you can
|
| 335 | create a callback function that does that. Let's create a simple example.</p>
|
| 336 |
|
| 337 | <p>In your controller, change the "username" rule to this:</p>
|
| 338 |
|
| 339 | <code>$rules['username'] = "callback_username_check"; </code>
|
| 340 |
|
| 341 | <p>Then add a new function called <dfn>username_check</dfn> to your controller. Here's how your controller should look:</p>
|
| 342 |
|
| 343 |
|
| 344 | <textarea class="textarea" style="width:100%" cols="50" rows="44"><?php
|
| 345 |
|
| 346 | class Form extends Controller {
|
| 347 |
|
| 348 | function index()
|
| 349 | {
|
| 350 | $this->load->helper(array('form', 'url'));
|
| 351 |
|
| 352 | $this->load->library('validation');
|
| 353 |
|
| 354 | $rules['username'] = "callback_username_check";
|
| 355 | $rules['password'] = "required";
|
| 356 | $rules['passconf'] = "required";
|
| 357 | $rules['email'] = "required";
|
| 358 |
|
| 359 | $this->validation->set_rules($rules);
|
| 360 |
|
| 361 | if ($this->validation->run() == FALSE)
|
| 362 | {
|
| 363 | $this->load->view('myform');
|
| 364 | }
|
| 365 | else
|
| 366 | {
|
| 367 | $this->load->view('formsuccess');
|
| 368 | }
|
| 369 | }
|
| 370 |
|
| 371 | function username_check($str)
|
| 372 | {
|
| 373 | if ($str == 'test')
|
| 374 | {
|
| 375 | $this->validation->set_message('username_check', 'The %s field can not be the word "test"');
|
| 376 | return FALSE;
|
| 377 | }
|
| 378 | else
|
| 379 | {
|
| 380 | return TRUE;
|
| 381 | }
|
| 382 | }
|
| 383 |
|
| 384 | }
|
| 385 | ?></textarea>
|
| 386 |
|
| 387 | <p>Reload your form and submit it with the word "test" as the username. You can see that the form field data was passed to your
|
| 388 | callback function for you to process.</p>
|
| 389 |
|
| 390 | <p><strong>To invoke a callback just put the function name in a rule, with "callback_" as the rule prefix.</strong></p>
|
| 391 |
|
admin | e334c47 | 2006-10-21 19:44:22 +0000 | [diff] [blame] | 392 | <p>The error message was set using the <dfn>$this->validation->set_message</dfn> function.
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 393 | Just remember that the message key (the first parameter) must match your function name.</p>
|
| 394 |
|
admin | e334c47 | 2006-10-21 19:44:22 +0000 | [diff] [blame] | 395 | <p class="important"><strong>Note:</strong> You can apply your own custom error messages to any rule, just by setting the
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 396 | message similarly. For example, to change the message for the "required" rule you will do this:</p>
|
| 397 |
|
| 398 | <code>$this->validation->set_message('required', 'Your custom message here');</code>
|
| 399 |
|
| 400 | <h2>Re-populating the form</h2>
|
| 401 |
|
admin | e334c47 | 2006-10-21 19:44:22 +0000 | [diff] [blame] | 402 | <p>Thus far we have only been dealing with errors. It's time to repopulate the form field with the submitted data.
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 403 | This is done similarly to your rules. Add the following code to your controller, just below your rules:</p>
|
| 404 |
|
| 405 | <code>$fields['username'] = 'Username';<br />
|
| 406 | $fields['password'] = 'Password';<br />
|
| 407 | $fields['passconf'] = 'Password Confirmation';<br />
|
| 408 | $fields['email'] = 'Email Address';<br />
|
| 409 | <br />
|
| 410 | $this->validation->set_fields($fields);</code>
|
| 411 |
|
admin | e334c47 | 2006-10-21 19:44:22 +0000 | [diff] [blame] | 412 | <p>The array keys are the actual names of the form fields, the value represents the full name that you want shown in the
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 413 | error message.</p>
|
| 414 |
|
| 415 | <p>The index function of your controller should now look like this:</p>
|
| 416 |
|
| 417 |
|
| 418 | <textarea class="textarea" style="width:100%" cols="50" rows="30">function index()
|
| 419 | {
|
| 420 | $this->load->helper(array('form', 'url'));
|
| 421 |
|
| 422 | $this->load->library('validation');
|
| 423 |
|
| 424 | $rules['username'] = "required";
|
| 425 | $rules['password'] = "required";
|
| 426 | $rules['passconf'] = "required";
|
| 427 | $rules['email'] = "required";
|
| 428 |
|
| 429 | $this->validation->set_rules($rules);
|
| 430 |
|
| 431 | $fields['username'] = 'Username';
|
| 432 | $fields['password'] = 'Password';
|
| 433 | $fields['passconf'] = 'Password Confirmation';
|
| 434 | $fields['email'] = 'Email Address';
|
| 435 |
|
| 436 | $this->validation->set_fields($fields);
|
| 437 |
|
| 438 | if ($this->validation->run() == FALSE)
|
| 439 | {
|
| 440 | $this->load->view('myform');
|
| 441 | }
|
| 442 | else
|
| 443 | {
|
| 444 | $this->load->view('formsuccess');
|
| 445 | }
|
| 446 | }</textarea>
|
| 447 |
|
| 448 |
|
| 449 | <p>Now open your <dfn>myform.php</dfn> view file and update the value in each field so that it has an object corresponding to its name:</p>
|
| 450 |
|
| 451 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 452 | <textarea class="textarea" style="width:100%" cols="50" rows="30">
|
| 453 | <html>
|
| 454 | <head>
|
| 455 | <title>My Form</title>
|
| 456 | </head>
|
| 457 | <body>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 458 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 459 | <?=$this->validation->error_string; ?>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 460 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 461 | <?=form_open('form'); ?>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 462 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 463 | <h5>Username</h5>
|
| 464 | <input type="text" name="username" value="<?=$this->validation->username;?>" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 465 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 466 | <h5>Password</h5>
|
| 467 | <input type="text" name="password" value="<?=$this->validation->password;?>" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 468 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 469 | <h5>Password Confirm</h5>
|
| 470 | <input type="text" name="passconf" value="<?=$this->validation->passconf;?>" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 471 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 472 | <h5>Email Address</h5>
|
| 473 | <input type="text" name="email" value="<?=$this->validation->email;?>" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 474 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 475 | <div><input type="submit" value="Submit" /></div>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 476 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 477 | </form>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 478 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 479 | </body>
|
| 480 | </html>
|
| 481 | </textarea>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 482 |
|
| 483 |
|
| 484 | <p>Now reload your page and submit the form so that it triggers an error. Your form fields should be populated
|
| 485 | and the error messages will contain a more relevant field name.</p>
|
| 486 |
|
| 487 |
|
| 488 |
|
| 489 | <h2>Showing Errors Individually</h2>
|
| 490 |
|
| 491 | <p>If you prefer to show an error message next to each form field, rather than as a list, you can change your form so that it looks like this:</p>
|
| 492 |
|
| 493 |
|
Derek Allard | c2c2561 | 2007-07-19 23:12:49 +0000 | [diff] [blame] | 494 | <textarea class="textarea" style="width:100%" cols="50" rows="20">
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 495 | <h5>Username</h5>
|
| 496 | <?=$this->validation->username_error; ?>
|
| 497 | <input type="text" name="username" value="<?=$this->validation->username;?>" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 498 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 499 | <h5>Password</h5>
|
| 500 | <?=$this->validation->password_error; ?>
|
| 501 | <input type="text" name="password" value="<?=$this->validation->password;?>" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 502 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 503 | <h5>Password Confirm</h5>
|
| 504 | <?=$this->validation->passconf_error; ?>
|
| 505 | <input type="text" name="passconf" value="<?=$this->validation->passconf;?>" size="50" />
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 506 |
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 507 | <h5>Email Address</h5>
|
| 508 | <?=$this->validation->email_error; ?>
|
Derek Allard | c2c2561 | 2007-07-19 23:12:49 +0000 | [diff] [blame] | 509 | <input type="text" name="email" value="<?=$this->validation->email;?>" size="50" /></textarea>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 510 |
|
| 511 | <p>If there are no errors, nothing will be shown. If there is an error, the message will appear, wrapped in the delimiters you
|
| 512 | have set (<p> tags by default).</p>
|
| 513 |
|
| 514 | <p class="important"><strong>Note: </strong>To display errors this way you must remember to set your fields using the <kbd>$this->validation->set_fields</kbd>
|
admin | e334c47 | 2006-10-21 19:44:22 +0000 | [diff] [blame] | 515 | function described earlier. The errors will be turned into variables that have "_error" after your field name.
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 516 | For example, your "username" error will be available at:<br /><dfn>$this->validation->username_error</dfn>.</p>
|
| 517 |
|
| 518 |
|
| 519 | <h2>Rule Reference</h2>
|
| 520 |
|
| 521 | <p>The following is a list of all the native rules that are available to use:</p>
|
| 522 |
|
| 523 |
|
| 524 |
|
| 525 | <table cellpadding="0" cellspacing="1" border="0" style="width:100%" class="tableborder">
|
| 526 | <tr>
|
| 527 | <th>Rule</th>
|
| 528 | <th>Parameter</th>
|
| 529 | <th>Description</th>
|
| 530 | <th>Example</th>
|
| 531 | </tr><tr>
|
| 532 |
|
| 533 | <td class="td"><strong>required</strong></td>
|
| 534 | <td class="td">No</td>
|
| 535 | <td class="td">Returns FALSE if the form element is empty.</td>
|
| 536 | <td class="td"> </td>
|
| 537 | </tr><tr>
|
| 538 |
|
| 539 | <td class="td"><strong>matches</strong></td>
|
| 540 | <td class="td">Yes</td>
|
| 541 | <td class="td">Returns FALSE if the form element does not match the one in the parameter.</td>
|
| 542 | <td class="td">matches[form_item]</td>
|
| 543 | </tr><tr>
|
| 544 |
|
| 545 | <td class="td"><strong>min_length</strong></td>
|
| 546 | <td class="td">Yes</td>
|
| 547 | <td class="td">Returns FALSE if the form element is shorter then the parameter value.</td>
|
| 548 | <td class="td">min_length[6]</td>
|
| 549 | </tr><tr>
|
| 550 |
|
| 551 | <td class="td"><strong>max_length</strong></td>
|
| 552 | <td class="td">Yes</td>
|
| 553 | <td class="td">Returns FALSE if the form element is longer then the parameter value.</td>
|
| 554 | <td class="td">max_length[12]</td>
|
| 555 | </tr><tr>
|
| 556 |
|
| 557 | <td class="td"><strong>exact_length</strong></td>
|
| 558 | <td class="td">Yes</td>
|
| 559 | <td class="td">Returns FALSE if the form element is not exactly the parameter value.</td>
|
| 560 | <td class="td">exact_length[8]</td>
|
| 561 | </tr><tr>
|
| 562 |
|
| 563 | <td class="td"><strong>alpha</strong></td>
|
| 564 | <td class="td">No</td>
|
| 565 | <td class="td">Returns FALSE if the form element contains anything other than alphabetical characters.</td>
|
| 566 | <td class="td"> </td>
|
| 567 | </tr><tr>
|
| 568 |
|
| 569 | <td class="td"><strong>alpha_numeric</strong></td>
|
| 570 | <td class="td">No</td>
|
| 571 | <td class="td">Returns FALSE if the form element contains anything other than alpha-numeric characters.</td>
|
| 572 | <td class="td"> </td>
|
| 573 | </tr><tr>
|
| 574 |
|
| 575 | <td class="td"><strong>alpha_dash</strong></td>
|
| 576 | <td class="td">No</td>
|
| 577 | <td class="td">Returns FALSE if the form element contains anything other than alpha-numeric characters, underscores or dashes.</td>
|
| 578 | <td class="td"> </td>
|
| 579 | </tr><tr>
|
| 580 |
|
| 581 | <td class="td"><strong>numeric</strong></td>
|
| 582 | <td class="td">No</td>
|
| 583 | <td class="td">Returns FALSE if the form element contains anything other than numeric characters.</td>
|
| 584 | <td class="td"> </td>
|
| 585 | </tr><tr>
|
| 586 |
|
| 587 | <td class="td"><strong>valid_email</strong></td>
|
| 588 | <td class="td">No</td>
|
| 589 | <td class="td">Returns FALSE if the form element does not contain a valid email address.</td>
|
| 590 | <td class="td"> </td>
|
| 591 | </tr>
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 592 | <tr>
|
admin | 10c3f41 | 2006-10-08 07:21:12 +0000 | [diff] [blame] | 593 | <td class="td"><strong>valid_ip</strong></td>
|
| 594 | <td class="td">No</td>
|
| 595 | <td class="td">Returns FALSE if the supplied IP is not valid.</td>
|
| 596 | <td class="td"> </td>
|
| 597 | </tr>
|
| 598 |
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 599 | </table>
|
| 600 |
|
| 601 | <p><strong>Note:</strong> These rules can also be called as discreet functions. For example:</p>
|
| 602 |
|
| 603 | <code>$this->validation->required($string);</code>
|
| 604 |
|
| 605 | <p class="important"><strong>Note:</strong> You can also use any native PHP functions that permit one parameter.</p>
|
| 606 |
|
| 607 |
|
| 608 |
|
| 609 | <h2>Prepping Reference</h2>
|
| 610 |
|
| 611 | <p>The following is a list of all the prepping functions that are available to use:</p>
|
| 612 |
|
| 613 |
|
| 614 |
|
| 615 | <table cellpadding="0" cellspacing="1" border="0" style="width:100%" class="tableborder">
|
| 616 | <tr>
|
| 617 | <th>Name</th>
|
| 618 | <th>Parameter</th>
|
| 619 | <th>Description</th>
|
| 620 | </tr><tr>
|
| 621 |
|
| 622 | <td class="td"><strong>xss_clean</strong></td>
|
| 623 | <td class="td">No</td>
|
| 624 | <td class="td">Runs the data through the XSS filtering function, described in the <a href="input.html">Input Class</a> page.</td>
|
| 625 | </tr><tr>
|
| 626 |
|
| 627 | <td class="td"><strong>prep_for_form</strong></td>
|
| 628 | <td class="td">No</td>
|
| 629 | <td class="td">Converts special characters so that HTML data can be shown in a form field without breaking it.</td>
|
| 630 | </tr><tr>
|
| 631 |
|
| 632 | <td class="td"><strong>prep_url</strong></td>
|
| 633 | <td class="td">No</td>
|
| 634 | <td class="td">Adds "http://" to URLs if missing.</td>
|
| 635 | </tr><tr>
|
| 636 |
|
| 637 | <td class="td"><strong>strip_image_tags</strong></td>
|
| 638 | <td class="td">No</td>
|
| 639 | <td class="td">Strips the HTML from image tags leaving the raw URL.</td>
|
| 640 | </tr><tr>
|
| 641 |
|
| 642 | <td class="td"><strong>encode_php_tags</strong></td>
|
| 643 | <td class="td">No</td>
|
| 644 | <td class="td">Converts PHP tags to entities.</td>
|
| 645 | </tr>
|
| 646 |
|
| 647 | </table>
|
| 648 |
|
| 649 | <p class="important"><strong>Note:</strong> You can also use any native PHP functions that permit one parameter,
|
| 650 | like <kbd>trim</kbd>, <kbd>htmlspecialchars</kbd>, <kbd>urldecode</kbd>, etc.</p>
|
| 651 |
|
| 652 |
|
| 653 | <h2>Setting Custom Error Messages</h2>
|
| 654 |
|
| 655 | <p>All of the native error messages are located in the following language file: <dfn>language/english/validation_lang.php</dfn></p>
|
| 656 |
|
| 657 | <p>To set your own custom message you can either edit that file, or use the following function:</p>
|
| 658 |
|
| 659 | <code>$this->validation->set_message('<var>rule</var>', '<var>Error Message</var>');</code>
|
| 660 |
|
| 661 | <p>Where <var>rule</var> corresponds to the name of a particular rule, and <var>Error Message</var> is the text you would like displayed.</p>
|
| 662 |
|
| 663 |
|
admin | 82654c3 | 2006-10-20 23:07:40 +0000 | [diff] [blame] | 664 | <h2>Dealing with Select Menus, Radio Buttons, and Checkboxes</h2>
|
| 665 |
|
admin | e334c47 | 2006-10-21 19:44:22 +0000 | [diff] [blame] | 666 | <p>If you use select menus, radio buttons or checkboxes, you will want the state of
|
admin | e7e1dcd | 2006-10-21 18:04:01 +0000 | [diff] [blame] | 667 | these items to be retained in the event of an error. The Validation class has three functions that help you do this:</p>
|
admin | 82654c3 | 2006-10-20 23:07:40 +0000 | [diff] [blame] | 668 |
|
| 669 | <h2>set_select()</h2>
|
| 670 |
|
| 671 | <p>Permits you to display the menu item that was selected. The first parameter
|
| 672 | must contain the name of the select menu, the second parameter must contain the value of
|
| 673 | each item. Example:</p>
|
| 674 |
|
| 675 | <code>
|
| 676 | <select name="myselect"><br />
|
| 677 | <option value="one" <dfn><?= $this->validation->set_select('myselect', 'one'); ?></dfn> >One</option><br />
|
Derek Allard | 4e387c3 | 2007-12-22 16:41:29 +0000 | [diff] [blame] | 678 | <option value="two" <dfn><?= $this->validation->set_select('myselect', 'two'); ?></dfn> >Two</option><br />
|
admin | 82654c3 | 2006-10-20 23:07:40 +0000 | [diff] [blame] | 679 | <option value="three" <dfn><?= $this->validation->set_select('myselect', 'three'); ?></dfn> >Three</option><br />
|
| 680 | </select>
|
| 681 | </code>
|
| 682 |
|
| 683 |
|
| 684 | <h2>set_checkbox()</h2>
|
| 685 |
|
| 686 | <p>Permits you to display a checkbox in the state it was submitted. The first parameter
|
| 687 | must contain the name of the checkbox, the second parameter must contain its value. Example:</p>
|
| 688 |
|
Derek Allard | 3d378b1 | 2007-05-08 23:03:59 +0000 | [diff] [blame] | 689 | <code><input type="checkbox" name="mycheck" value="1" <dfn><?= $this->validation->set_checkbox('mycheck', '1'); ?></dfn> /></code>
|
admin | 82654c3 | 2006-10-20 23:07:40 +0000 | [diff] [blame] | 690 |
|
| 691 |
|
| 692 | <h2>set_radio()</h2>
|
| 693 |
|
| 694 | <p>Permits you to display radio buttons in the state they were submitted. The first parameter
|
| 695 | must contain the name of the radio button, the second parameter must contain its value. Example:</p>
|
| 696 |
|
Derek Allard | 3d378b1 | 2007-05-08 23:03:59 +0000 | [diff] [blame] | 697 | <code><input type="radio" name="myradio" value="1" <dfn><?= $this->validation->set_radio('myradio', '1'); ?></dfn> /></code>
|
admin | 82654c3 | 2006-10-20 23:07:40 +0000 | [diff] [blame] | 698 |
|
| 699 |
|
| 700 |
|
| 701 |
|
| 702 |
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 703 | </div>
|
| 704 | <!-- END CONTENT -->
|
| 705 |
|
| 706 |
|
| 707 | <div id="footer">
|
| 708 | <p>
|
Derek Allard | 9da4dbc | 2007-04-03 11:39:35 +0000 | [diff] [blame] | 709 | Previous Topic: <a href="user_agent.html">User Agent Class</a>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 710 | ·
|
| 711 | <a href="#top">Top of Page</a> ·
|
| 712 | <a href="../index.html">User Guide Home</a> ·
|
| 713 | Next Topic: <a href="xmlrpc.html">XML-RPC Class</a>
|
Derek Allard | c644128 | 2007-07-04 23:54:32 +0000 | [diff] [blame] | 714 | </p>
|
Derek Allard | d2df9bc | 2007-04-15 17:41:17 +0000 | [diff] [blame] | 715 | <p><a href="http://www.codeigniter.com">CodeIgniter</a> · Copyright © 2007 · <a href="http://ellislab.com/">Ellislab, Inc.</a></p>
|
admin | b0dd10f | 2006-08-25 17:25:49 +0000 | [diff] [blame] | 716 | </div>
|
| 717 |
|
| 718 | </body>
|
| 719 | </html> |