如果"md5"在前
array('password','md5',3,'function'), // 对password字段在新增的时候使md5函数处理
array('password','',2,'ignore'),//未填写密码时不更新
原本空的'password'经过md5加密之后生成了md5码,跳过了'ignore',数据库中的'password'字段被更新如果"ignore"在前
array('password','',2,'ignore'),//未填写密码时不更新
array('password','md5',3,'function'), // 对password字段在新增的时候使md5函数处理
虽然'password'经过'ignore'被'unset',但是接下来有被md5加密,返回空值,数据库中的'password'字段被更新后来我想了个土办法,修改框架中的"Model.class.php"。
//文件路径:ThinkPHP\Lib\Core\Model.class.php
//大概在第900行的位置
// 自动填充
if(isset($_auto)) {
foreach ($_auto as $auto){
// 填充因子定义格式
// array('field','填充内容','填充条件','附加规则',[额外参数])
if(empty($auto[2])) $auto[2] = self::MODEL_INSERT; // 默认为新增的时候自动填充
if( $type == $auto[2] || $auto[2] == self::MODEL_BOTH) {
switch(trim($auto[3])) {
case 'function': // 使用函数进行填充 字段的值作为参数
case 'callback': // 使用回调方法
$args = isset($auto[4])?(array)$auto[4]:array();
if(isset($data[$auto[0]])) {
array_unshift($args,$data[$auto[0]]);
}
if('function'==$auto[3]) {
$data[$auto[0]] = call_user_func_array($auto[1], $args);
}else{
$data[$auto[0]] = call_user_func_array(array(&$this,$auto[1]), $args);
}
break;
case 'field': // 用其它字段的值进行填充
$data[$auto[0]] = $data[$auto[1]];
break;
case 'ignore': // 为空忽略
// if(''===$data[$auto[0]]) //这是框架原先的判断条件
if(''===$data[$auto[0]]||'d41d8cd98f00b204e9800998ecf8427e'===$data[$auto[0]]) //这是修改后的
unset($data[$auto[0]]);
break;
case 'string':
default: // 默认作为字符串填充
$data[$auto[0]] = $auto[1];
}
if(false === $data[$auto[0]] ) unset($data[$auto[0]]);
}
}
}
@thinkphp_dy @thinkphp 最佳答案
