一、主要函数
//在文件Form_validation.php
/**
* Set Rules
*
* This function takes an array of field names and validation
* rules as input, any custom error messages, validates the info,
* and stores it
*
* @param mixed $field 需要验证的字段可以为数组
* @param string $label 返回错误信息时的字段别称
* @param mixed $rules 验证规则可以使数组
* @param array $errors 错误提示信息
* @return CI_Form_validation
*/
public function set_rules($field, $label = '', $rules = array(), $errors = array())
/*
*添加验证的表单信息,前后端分离时的json中的字段对应数据
* 格式 array("username"=>"admin");
* @param array $data
* @return CI_Form_validation
*/
public function set_data(array $data)
//运行规则 出入验证的配置组名称
public function run($filde)
/*
*返回验证未通过的字段结果数组
* @return array
*/
public function error_array()
二、自行封装到工具类My_common.php中
/**
* @Notes: 数据验证
* @Function form_verify
* @param $data
* @param $rule
* @return bool
*/
public function form_verify($data, $rule)
{
$this->CI->load->helper(array('form', 'url'));
$this->CI->load->library('form_validation');
//验证传输过来的数据必须定义为数组,以及不能为空
if(!empty($rules) || !is_array($data)){
$error['msg'] = "验证数据格式错误!";
$error['sign'] = FALSE;
return $error;
}
//将前端提交数据添加到CI验证过程中
$this->CI->form_validation->set_data($data);
//添加验证
if ($this->CI->form_validation->run($rule) == FALSE) {
$error['msg'] = $this->CI->form_validation->error_array();
$error['sign'] = FALSE;
return $error;
} else {
$error['sign'] = TRUE;
return $error;
}
}
三、写规则form_validation.php
<?php
$config = array(
'article' => array(
array(
'field' => 'ent_name',
'label' => '企业名称',
'rules' => 'required|min_length[1]',
'errors' => array(
'required' => '%s不能为空',
'min_length' => '%s最短为1个字符',
),
),
array(
'field' => 'type',
'label' => '类型',
'rules' => 'required|integer'
),
array(
'field' => 'cid',
'label' => '栏目',
'rules' => 'integer'
),
array(
'field' => 'info',
'label' => '摘要',
'rules' => 'required|max_length[155]'
),
array(
'field' => 'content',
'label' => '内容',
'rules' => 'required|max_length[2000]'
)
),
'cate' => array(
array(
'field' => 'cname',
'label' => '栏目名称',
'rules' => 'required|max_length[20]'
),
),
);
四、应用
/**
* 验证函数
*/
public function test_form()
{
$data = $this->json_input();
//写入验证数据数组以及验证规则配置文件中的名称
$result = $this->my_common->form_verify($data, "article");
if (!$result['sign']) {//验证未通过
$this->util($result['msg']);
return;
}
//业务逻辑代码
}