我有一个辅助函数来检查用户名是否有效。
在帮助文件中:
if ( ! function_exists('valid_username'))
{
function valid_username($username)
{
$ci=& get_instance();
$ci->load->database();
if (empty($username) OR !preg_match("/^[a-z]([0-9a-z_-])+[0-9a-z]$/i", $username)) //Allowed a-z, 0-9, and underscores. Must end in a-z or 0-9.
{
$ci->form_validation->set_message('valid_username', 'Characters not valid.');
return FALSE;
}
$ci->db->select('username');
$ci->db->where('username', $username);
$ci->db->where('activated', 1);
$ci->db->where('banned', 0);
$ci->db->limit(1);
$query = $ci->db->get('users');
if ($query->num_rows() > 0) //if user exists
{
return TRUE;
}
else
{
$ci->form_validation->set_message('valid_username', 'The %s does not exist.');
return FALSE;
}
}
}
在我的控制器中,我将帮助器添加到表单验证中:
$this->form_validation->set_rules('username', 'Username', 'trim|required|xss_clean|min_length[2]|max_length[50]|callback_valid_username');
//add callback from helper function
function valid_username($username)
{
return valid_username($username);
}
这很有效但是我必须像这样私有化回调:
$this->form_validation->set_rules('username', 'Username', 'trim|required|xss_clean|min_length[2]|max_length[50]|callback__valid_username');
function _valid_username($username)
{
return valid_username($username);
}
将回调设为私有后,我在提交无效用户名时收到以下消息:
无法访问与您的字段名称对应的错误消息。
我在这里做错了什么?
答案 0 :(得分:2)
我不是百分百确定为什么私有功能破坏了你的错误消息,但我可以建议一个解决方法:
表单验证规则允许任何最多接受1个参数的函数用作验证或准备规则。所以基本上,当前脚本可用的任何内容都可以作为表单验证规则使用,包括valid_username()
函数。试试这个(只需将其添加到其他规则中):
$this->form_validation->set_rules('username', 'Username', 'valid_username');
因此,您不需要将控制器方法作为包装器,并且您不需要使用callback_
。
看看它是否适合您。< / p>
除了:我建议您在定义function_exists()
时跳过valid_username()
来电,除非您确定您想要允许该功能被“覆盖”。
答案 1 :(得分:0)
您可以使用任何可调用的内容作为规则。即使它是助手的功能。 Check it out
正确的语法是:
$this->form_validation->set_rules(
'username', 'Username', array('required', array('valid_username_callable', 'valid_username')));
在帮助程序中,如有必要,请设置错误消息,如下所示:
$CI = &get_instance();
$CI->form_validation->set_message('valid_username_callable', 'Error message');