thinkPHP自动验证无效,没有报错
2014-11-13 16:30
239 查看
thinkPHP自动验证无效,或者验证的时候没有提示。出现这样的问题就让我们来看看model类里的自动验证函数。
先来看看自动验证的使用问题。模型
控制器
定义好了,提交自动验证就OK了。
但是有的时候却会出现一些问题导致验证不成功或者失效。如果出现这类问题,我们需要先保证你的验证规则必须正确。
没有问题这里我们就需要去到核心类库里的model类看看。
#824的create方法里
public function create($data='',$type='') {
// 如果没有传值默认取POST数据
if(empty($data)) {
$data = I('post.');
}elseif(is_object($data)){
$data = get_object_vars($data);
}
// 验证数据
if(empty($data) || !is_array($data)) {
$this->error = L('_DATA_TYPE_INVALID_');
return false;
}
// 状态
$type = $type?$type:(!empty($data[$this->getPk()])?self::MODEL_UPDATE:self::MODEL_INSERT);
// 检查字段映射
if(!empty($this->_map)) {
foreach ($this->_map as $key=>$val){
if(isset($data[$key])) {
$data[$val] = $data[$key];
unset($data[$key]);
}
}
}
// 检测提交字段的合法性
if(isset($this->options['field'])) { // $this->field('field1,field2...')->create()
$fields = $this->options['field'];
unset($this->options['field']);
}elseif($type == self::MODEL_INSERT && isset($this->insertFields)) {
$fields = $this->insertFields;
}elseif($type == self::MODEL_UPDATE && isset($this->updateFields)) {
$fields = $this->updateFields;
}
if(isset($fields)) {
if(is_string($fields)) {
$fields = explode(',',$fields);
}
// 判断令牌验证字段
if(C('TOKEN_ON')) $fields[] = C('TOKEN_NAME');
foreach ($data as $key=>$val){
if(!in_array($key,$fields)) {
unset($data[$key]);
}
}
}
// 数据自动验证
if(!$this->autoValidation($data,$type)) return false;
// 表单令牌验证
if(!$this->autoCheckToken($data)) {
$this->error = L('_TOKEN_ERROR_');
return false;
}
// 验证完成生成数据对象
if($this->autoCheckFields) { // 开启字段检测 则过滤非法字段数据
$fields = $this->getDbFields();
foreach ($data as $key=>$val){
if(!in_array($key,$fields)) {
unset($data[$key]);
}elseif(MAGIC_QUOTES_GPC && is_string($val)){
$data[$key] = stripslashes($val);
}
}
}
// 创建完成对数据进行自动处理
$this->autoOperation($data,$type);
// 赋值当前数据对象
$this->data = $data;
// 返回创建的数据以供其他调用
return $data;
}
这里查看一下返回false的各个地方
这里有个字段映射问题,如果你的提交表单数据和数据表的字段完全不一样,且你又没有设置字段映射,那么经过下面这段代码
if($this->autoCheckFields) { // 开启字段检测 则过滤非法字段数据
$fields = $this->getDbFields();
foreach ($data as $key=>$val){
if(!in_array($key,$fields)) {
unset($data[$key]);
}elseif(MAGIC_QUOTES_GPC && is_string($val)){
$data[$key] = stripslashes($val);
}
}
}
过滤后,你的create方法最终还是返回false,所以明明格式都是对的,提交却还是不能通过的原因。
开启表单令牌后,会验证表单令牌,不通过会有提示令牌错误。
先来看看自动验证的使用问题。模型
控制器
定义好了,提交自动验证就OK了。
但是有的时候却会出现一些问题导致验证不成功或者失效。如果出现这类问题,我们需要先保证你的验证规则必须正确。
没有问题这里我们就需要去到核心类库里的model类看看。
#824的create方法里
public function create($data='',$type='') {
// 如果没有传值默认取POST数据
if(empty($data)) {
$data = I('post.');
}elseif(is_object($data)){
$data = get_object_vars($data);
}
// 验证数据
if(empty($data) || !is_array($data)) {
$this->error = L('_DATA_TYPE_INVALID_');
return false;
}
// 状态
$type = $type?$type:(!empty($data[$this->getPk()])?self::MODEL_UPDATE:self::MODEL_INSERT);
// 检查字段映射
if(!empty($this->_map)) {
foreach ($this->_map as $key=>$val){
if(isset($data[$key])) {
$data[$val] = $data[$key];
unset($data[$key]);
}
}
}
// 检测提交字段的合法性
if(isset($this->options['field'])) { // $this->field('field1,field2...')->create()
$fields = $this->options['field'];
unset($this->options['field']);
}elseif($type == self::MODEL_INSERT && isset($this->insertFields)) {
$fields = $this->insertFields;
}elseif($type == self::MODEL_UPDATE && isset($this->updateFields)) {
$fields = $this->updateFields;
}
if(isset($fields)) {
if(is_string($fields)) {
$fields = explode(',',$fields);
}
// 判断令牌验证字段
if(C('TOKEN_ON')) $fields[] = C('TOKEN_NAME');
foreach ($data as $key=>$val){
if(!in_array($key,$fields)) {
unset($data[$key]);
}
}
}
// 数据自动验证
if(!$this->autoValidation($data,$type)) return false;
// 表单令牌验证
if(!$this->autoCheckToken($data)) {
$this->error = L('_TOKEN_ERROR_');
return false;
}
// 验证完成生成数据对象
if($this->autoCheckFields) { // 开启字段检测 则过滤非法字段数据
$fields = $this->getDbFields();
foreach ($data as $key=>$val){
if(!in_array($key,$fields)) {
unset($data[$key]);
}elseif(MAGIC_QUOTES_GPC && is_string($val)){
$data[$key] = stripslashes($val);
}
}
}
// 创建完成对数据进行自动处理
$this->autoOperation($data,$type);
// 赋值当前数据对象
$this->data = $data;
// 返回创建的数据以供其他调用
return $data;
}
这里查看一下返回false的各个地方
这里有个字段映射问题,如果你的提交表单数据和数据表的字段完全不一样,且你又没有设置字段映射,那么经过下面这段代码
if($this->autoCheckFields) { // 开启字段检测 则过滤非法字段数据
$fields = $this->getDbFields();
foreach ($data as $key=>$val){
if(!in_array($key,$fields)) {
unset($data[$key]);
}elseif(MAGIC_QUOTES_GPC && is_string($val)){
$data[$key] = stripslashes($val);
}
}
}
过滤后,你的create方法最终还是返回false,所以明明格式都是对的,提交却还是不能通过的原因。
开启表单令牌后,会验证表单令牌,不通过会有提示令牌错误。
相关文章推荐
- ThinkPHP 自动验证与自动填充无效可能的原因
- ThinkPHP 自动验证与自动填充无效可能的原因
- Thinkphp3.2自动验证和自动完成无效
- thinkphp 在数据库更新(save)的时候,如果字段没有被修改,会更新失败 和数据的自动验证,插入的时候可以自动验证,但更新的时候就不能验证了
- ThinkPHP 自动验证与自动填充无效可能的原因
- <转>thinkphp自动验证无效的问题
- thinkphp自动验证功能一直没有实现,这是为什么呢?
- ThinkPHP 自动验证与自动填充无效可能的原因
- ThinkPHP 自动验证与自动填充无效可能的原因
- thinkphp自动验证无效的问题
- ThinkPHP 自动验证与自动填充无效可能的原因
- ThinkPHP 自动验证
- ThinkPHP 自动验证及验证规则详解!
- thinkphp3.2微信开发者模式 绑定url token 您的服务器没有正确相应token验证
- ThinkPHP 自动验证及验证规则详解
- thinkphp3.2开发排错一例——没有使用命名空间导致没有自动加载类进而导致Class not found
- Thinkphp 自动验证
- filter验证登录失败后为什么没有自动跳转到登录页面?
- THINKPHP自动验证,自动完成,字段…
- Thinkphp生成验证码与自动验证