CI框架学习之四(表单验证)

2017-09-22 15:17:35 CodeIgniter

1、form头部信息的自动输出函数(view)

<?php   
  $attributes = array('class' => 'email', 'id' => 'myform');  
  echo form_open('email/send', $attributes);  
  
  //上面一行代码输出:  
  //<form method="post" accept-charset="utf-8" action="http://example.com/index.php/email/send" id="myform" class="email"/>  
    
  /*   
  * form_open_multipart() 
  * 函数用法同上,加上了文件上传的信息 上传方式默认为post 
  */  
?>  

2、设置验证规则(controller)

<?php  
//注意验证规则的变量名必须设置成 config  
$config = array(  
               array(  
                     'field'   => 'username',   
                     'label'   => '用户名',   
                     'rules'   => 'required'  
                  ),  
               array(  
                     'field'   => 'password',   
                     'label'   => '密码',   
                     'rules'   => 'required'  
                  ),  
               array(  
                     'field'   => 'passconf',   
                     'label'   => '确认密码',   
                     'rules'   => 'required|matches[password]'  
                  ),   
               array(  
                     'field'   => 'tel',   
                     'label'   => '手机',   
                     'rules'   => 'required|integer|exact_length[11]'),  
               array(  
                     'field'   => 'email',   
                     'label'   => '邮箱',   
                     'rules'   => 'required|valid_email'  
                  )  
            );  
//上面的会自动  
//单独设置规则  
$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');  
  
?>  

3、规则对应的错误提示(controller)

<?php  
$this->form_validation->set_message('required', '必须填写');  
$this->form_validation->set_message('valid_email', '不是有效的email');  
?>  

4、运行检查错误信息(controller)

<?php   
  $this->load->helper(array('form', 'url'));  
  //加载CI表单验证库  
  $this->load->library('form_validation');  
  //----------------------------------------  
  #  验证规则及错误信息代码放在这里  
  //----------------------------------------  
  if ($this->form_validation->run() == FALSE){  
      //提交失败 重新加载表单部分  
      $this->load->view('myform');  
  }else{  
      //提交成功 表单处理  
      //跳转成功页面  
      $this->load->view('formsuccess');  
  }  
}  

5、错误信息的输出函数(view)

<?php  
    //1.一股脑儿的全部输出(放在表单标签的上方即可)  
    echo validation_errors();   
    //2.针对单个表单单独输出(放在单个标签附近 参数为对应表单元素的域名)  
    echo form_error('password');   
    //3.针对单个表单输出的时候 需要修改定界符 显示错误信息样式(控制器里设置)  
    $this->form_validation->set_error_delimiters('<span class="error">', '</span>');  
    //设置成内联元素比较好  
?> 

6、错误后 重新回填表单(view)

<?php
  //一般元素 回填(放在标签的values属性中输出)
  echo set_value('email'); 
  //特殊元素select/checkbox/radio 第三个参数为true时 默认被选中
  //第二个参数 是对应的表单元素的实际值
  echo set_select('myselect', 'three'); //放在option的空白属性里
  echo set_checkbox('mycheck[]', '1');  //放在checkbox的空白属性里
  echo set_radio('myradio', '2');       //放在radio的空白属性里

?>

【html代码】
<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="<?php  echo set_value('username'); ?>" size="50" />  
    <?php echo form_error('username'); ?>  
  
    <h5>Password</h5>  
    <input type="text" name="password" value="<?php  echo set_value('password'); ?>" size="50" />  
    <?php echo form_error('password'); ?>  
  
    <h5>Password Confirm</h5>  
    <input type="text" name="passconf" value="<?php  echo set_value('passconf'); ?>" size="50" />  
    <?php echo form_error('passconf'); ?>  
  
    <h5>Email Address</h5>  
    <input type="text" name="email" value="<?php  echo set_value('email'); ?>" size="50" />  
    <?php echo form_error('email'); ?>  
  
    <div><input type="submit" value="Submit" /></div>  
  
</form>  
  
</body>  
</html>  

文章来源 http://blog.csdn.net/wujiangwei567/article/details/44588929