首页 > 代码库 > CI表单验证
CI表单验证
一、CodeIgniter允许你为单个表单域创建多个验证规则,按顺序层叠在一起,你甚至可以同时预先处理表单域数据。要设置验证规则请使用set_rules() 函数:
上面的函数使用 三个 参数作为输入:
- 表单域的名字 - 就是你给表单域取的那个名字。
- 一个此表单域的 "人性化" 名字,它将被插入到错误信息中。例如,如果你有一个表单域叫做“user”你可能给它一个人性化名字叫做“用户名”。 注意: 如果你想让表单域的名字保存在一个语言文件里。
- 为此表单域设置的验证规则。
$this->form_validation->set_rules(‘username‘, ‘Username‘, ‘required‘);$this->form_validation->set_rules(‘password‘, ‘Password‘, ‘required‘);$this->form_validation->set_rules(‘passconf‘, ‘Password Confirmation‘, ‘required‘);$this->form_validation->set_rules(‘email‘, ‘Email‘, ‘required‘);
上面是一段示例代码。
<?phpclass Form extends CI_Controller { function index() { $this->load->helper(array(‘form‘, ‘url‘)); $this->load->library(‘form_validation‘); $this->form_validation->set_rules(‘username‘, ‘Username‘, ‘required‘); $this->form_validation->set_rules(‘password‘, ‘Password‘, ‘required‘); $this->form_validation->set_rules(‘passconf‘, ‘Password Confirmation‘, ‘required‘); $this->form_validation->set_rules(‘email‘, ‘Email‘, ‘required‘); if ($this->form_validation->run() == FALSE) { $this->load->view(‘myform‘); } else { $this->load->view(‘formsuccess‘); } }}?>
控制器的内容如上。
二、使用数组设置验证规则:
$config = array( array( ‘field‘ => ‘username‘, ‘label‘ => ‘Username‘, ‘rules‘ => ‘required‘ ), array( ‘field‘ => ‘password‘, ‘label‘ => ‘Password‘, ‘rules‘ => ‘required‘ ), array( ‘field‘ => ‘passconf‘, ‘label‘ => ‘Password Confirmation‘, ‘rules‘ => ‘required‘ ), array( ‘field‘ => ‘email‘, ‘label‘ => ‘Email‘, ‘rules‘ => ‘required‘ ) );$this->form_validation->set_rules($config);
三、级联规则:
$this->form_validation->set_rules(‘username‘, ‘Username‘, ‘required|min_length[5]|max_length[12]‘);$this->form_validation->set_rules(‘password‘, ‘Password‘, ‘required|matches[passconf]‘);$this->form_validation->set_rules(‘passconf‘, ‘Password Confirmation‘, ‘required‘);$this->form_validation->set_rules(‘email‘, ‘Email‘, ‘required|valid_email‘);
上面的代码设置了一组规则:
- 用户名表单域长度不得小于5个字符以及大于12个字符。
- 密码表单域必须跟密码确认表单域的数据一致。
- 电子邮件表单域必须是一个有效邮件地址。
四、预处理数据
$this->form_validation->set_rules(‘username‘, ‘Username‘, ‘trim|required|min_length[5]|max_length[12]|xss_clean‘);$this->form_validation->set_rules(‘password‘, ‘Password‘, ‘trim|required|matches[passconf]|md5‘);$this->form_validation->set_rules(‘passconf‘, ‘Password Confirmation‘, ‘trim|required‘);$this->form_validation->set_rules(‘email‘, ‘Email‘, ‘trim|required|valid_email‘);
在上面的例子里,我们“修整(trimming,去掉字符串两端空白)”了数据,转换密码为MD5,将用户名通过“xss_clean”函数处理去掉了有害数据。
任何PHP自身接收一个参数的函数都可以被用作一个规则,比如 htmlspecialchars, trim, MD5, 等。
五、重新填充表单
set_value(‘field name‘)
不要忘记在set_value()函数中包含每个表单域的名字!
<html><head><title>My Form</title></head><body><?php echo validation_errors(); ?><?php echo form_open(‘form‘); ?><h5>Username</h5><input type="text" name="username" value="http://www.mamicode.com/<?php echo set_value(‘username‘); ?>" size="50" /><h5>Password</h5><input type="text" name="password" value="http://www.mamicode.com/<?php echo set_value(‘password‘); ?>" size="50" /><h5>Password Confirm</h5><input type="text" name="passconf" value="http://www.mamicode.com/<?php echo set_value(‘passconf‘); ?>" size="50" /><h5>Email Address</h5><input type="text" name="email" value="http://www.mamicode.com/<?php echo set_value(‘email‘); ?>" size="50" /><div><input type="submit" value="http://www.mamicode.com/Submit" /></div></form></body></html>
六、设置错误信息
$this->form_validation->set_message(‘rule‘, ‘Error Message‘);
你也可以重写语言文件中的错误信息. 例如, 你可以这么做来改变"required" 规则的信息:
$this->form_validation->set_message(‘required‘, ‘Your custom message here‘);
七、更改错误定界符
在默认情况下,表单验证类会使用 (<p>) 标签来分割每条错误信息,以达到分段效果。你可以自行对其进行定义。
- 定界符统一更改
如果需要全局更改错误定界符, 可以在你的控制器中,在表单验证类加载之后添加如下代码:
$this->form_validation->set_error_delimiters(‘<div class="error">‘, ‘</div>‘);
在此例中,我们将定界符由系统默认的 <p> 更改为一个div标签。
- 定界符单独更改
表单验证类所提供的两种显示错误验证信息的函数,分别可以通过如下方法来设置它们的定界符:
<?php echo form_error(‘field name‘, ‘<div class="error">‘, ‘</div>‘); ?>
或者:
<?php echo validation_errors(‘<div class="error">‘, ‘</div>‘); ?>
CI表单验证
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。