搜尋

首頁  >  問答  >  主體

關於 ThinkPHP 中自動驗證的問題

![圖片上傳...]

    public function addUserBasicData($username,$password,$user_type,$email,$phone,$onlyuid = '598E0CD9'){
        if (empty($username)) {
            $username = "用户".mt_rand();
        }
        $data['username'] = $username;
        $data['onlyuid'] = $onlyuid;
        $data['password'] = $password;
        $data['user_type'] = $user_type;
        $data['email'] = $email;
        $data['phone'] = $phone;
        $data['regdate'] = NOW_TIME; 

        $rules = array(
            array('onlyuid','','身份重复',0,'unique',1),
            array('phone','require','手机号码非法','/^(13|14|15|16|17|18)\d{9}$$/'), 
            array('phone','','您输入手机号码已经被注册!',0,'unique',1), 
            array('email','','您输入电子邮箱已经被注册!',0,'unique',1), 
            array('password','require','您尚未填写密码!'), 
            array('user_type','require','您尚未选择用户类型!'),
            array('repassword','password','确认密码不正确',0,'confirm'), 
            array('password','checkPwd','密码格式不正确',0,'function'),
        );
        if (!$this->table('yy_common_member')->validate($rules)->create()){
            $return_value["status"] = "failed";
            $return_value["status_code"] = 40000;
            $return_value["status_message"] = $this->getError();;
            $return_value["data"]=  "";
            return $return_value;
               
        }else{
            $uid = $this->table('yy_common_member')->add($data);
            $data2['uid'] = $uid;
            $return_value["status"] = "success";
            $return_value["status_code"] = 20105;
            $return_value["status_message"] = "";
            $return_value["data"]=  $this->table('yy_common_member_profile')->add($data2);
            return $return_value;
        }

    }

以上是程式碼片段
分別設定了
array('onlyuid','','身分重複',0,'unique',1), 和array('phone','','您輸入手機號碼已經被註冊!
但前者不生效,後者可以使用

報錯


正常


滿天的星座滿天的星座2772 天前560

全部回覆(3)我來回復

  • 世界只因有你

    世界只因有你2017-05-16 13:11:54

    這明顯是sql語句報錯,跟驗證沒關係,插入的onlyuid重複了

    回覆
    0
  • 过去多啦不再A梦

    过去多啦不再A梦2017-05-16 13:11:54

    你資料庫中onlyuid欄位的資料型別是什麼?

    回覆
    0
  • 世界只因有你

    世界只因有你2017-05-16 13:11:54

    大家說的沒錯:原因在資料庫那裡,你試圖插入重複的onlyuid,而這個欄位顯然被設定為唯一的。

    檢查一下吧,如果這個字段字面意義不是很強,建議用自增形式,每次插入資料時不要直接跳過這個字段,讓他自己增加。

    還有一種可能,這個欄位要插入的值已經超過它允許的最大值了。

    回覆
    0
  • 取消回覆