#php #database #laravel
#php #База данных #laravel
Вопрос:
Когда новый пользователь заполняет регистрационную форму и нажимает отправить, я могу получить все данные, которые мне нужны, используя dd ($ var). Но при вставке в базу данных laravel сообщает, что не удается вставить значение NULL в столбец ‘password’ . Почему laravel не получил мой пароль при вставке в базу данных?
я понятия не имею, что я здесь сделал не так. помогите мне..
это мой RegisterController.php
protected function create(array $data)
{
$pw_hash = Hash::make($data['Password']);
$uuid4 = Uuid::uuid4();
$a = DB::table('Person.Person')->insert(array(
'PersonId' => $uuid4->toString(),
'PersonName' => $data['PersonName'],
'Email' => $data['Email'],
'IsActive' => false,
'IsLoginActive' => false,
'PasswordSalt' => substr($pw_hash, 7, 22),
'PasswordHash' => sha1($pw_inpt.''.$pw_salt),
'IsMale' => $data['IsMale'],
'Email' => $data['Email'],
'Phone' => $data['Phone'],
'LoginName' => $data['Email'],
'PersonName' => $data["NamaDepan"]." ".$data['NamaBelakang'],
'EmailVerifiedAt' => date('Y-m-d'),
'EmailVerified' => false,
'EmailVerificationCode'=> Hash::make(rand(0,100)),
'password'=> 'aaaapass',
));
dd($a);
}
и это мой User.php Модель
class User extends Authenticatable{
use Notifiable;
protected $table = 'Person.Person';
// protected $username = 'Email';
public $incrementing = false;
protected $primaryKey = 'PersonId';
const CREATED_AT = 'CreatedDate';
const UPDATED_AT = 'ModifiedDate';
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'PersonId',
'Email',
'Phone',
'IsMale',
'password',
'IsActive',
'Position',
'LoginName',
'kencur',
'ClusterId',
'BirthDate',
'BirthPlace',
'PersonName',
'PersonImage',
'PasswordSalt',
'PasswordHash',
'ModifiedDate',
'IsLoginActive',
'EmailVerified',
'WhatsappNumber',
'EmailVerifiedAt',
'EmailVerificationCode',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password',
'PasswordHash',
'PasswordSalt',
'remember_token',
];
public function getEmailForPasswordReset() {
return $this->Email;
}
}
и это то, что говорит laravel:
Cannot insert the value NULL into column 'password', table 'Assess2.Person.Person'; column does not allow nulls. INSERT fails. (SQL: insert into [Person].[Person] ([PersonId], [PersonName], [Email], [IsActive], [IsLoginActive], [PasswordSalt], [PasswordHash], [IsMale], [Phone], [LoginName], [EmailVerifiedAt], [EmailVerified], [EmailVerificationCode], [password]) values (f6377aeb-df36-4f38-aef5-40c7a2240cc5, has sutenan, namadcvbepan@gmail.com, 0, 0, CTDdYYCXHULY4ad8jQJ9WO, $2y$10$CTDdYYCXHULY4ad8jQJ9WOmVqCILEuJPHSgffLlVW5SK7b7Q4qMpy, true, 55, namadcvbepan@gmail.com, 2019-03-04, 0, $2y$10$vcHlXQgukHomPI.FJZe2XOyl0lJd3Lo5rDqVN5SU8gY3UloPLsr.C, aaaapass))
я использую laravel 5.7. спасибо
Комментарии:
1.
print_r
перед сохранением в БД посмотрите, что вы на самом деле отправляете в БД. посмотрите, соответствуют ли данные вашим требованиям
Ответ №1:
ПАРОЛЬ — это зарезервированное ключевое слово базы данных. Попробуйте переименовать этот столбец.
Комментарии:
1. Проблема не в имени столбца, проблема в том, что OP пытается вставить NULL в этот столбец,
2. я не уверен, что password — это ключевое слово reserved в laravel, потому что я всегда использую ‘password’ для сохранения пароля пользователя в моем другом проекте.
3. привет @Kratos, но я не хочу вставлять null. проблема в том, что у меня есть данные [a, b, c, d], и я хочу вставить их все в свою базу данных. Но laravel просто вставляет [a, b, d],
4. извините, я имел в виду, что laravel отправляет null, вы пробовали напечатать запрос?
5. похоже, что поле пароля не возвращается, попробуйте еще раз проверить свой html-код, чтобы избежать ошибок в написании пароля.