从 'User' 模型中提取电子邮件字段并通过外键将其添加到单独的模型 'Email'
Extract email field from 'User' model and add it to a seperate model 'Email' via foreign key
我是 Laravel 的新手,我被指示将字段 'email' 与 'User' 模型分开,而是使用与新的 foreign_id 对应的 foreign_id创建模型 'Email'.
用户:
public function up()
{
Schema::create('users', function (Blueprint $table) {
$table->id();
$table->integer('email_id');
$table->string('password');
$table->rememberToken();
$table->timestamps();
});
}
电子邮件:
public function up()
{
Schema::create('emails', function (Blueprint $table) {
$table->id();
$table->string('email')->unique();
$table->timestamp('email_verified_at')->nullable();
$table->boolean('is_active')->default(True);
$table->timestamps();
});
}
当然我已经在那些模型中设置了关系。
现在,当一个新用户通过表单注册时,我想检查输入的邮件地址是否已经存在于 'emails' table 中,以及可能已经找到的邮件地址是否具有 属性 'is_active' 设置为真。
目前 RegisterController 中的 'validator' 和 'create' 功能非常基础:
/**
* Get a validator for an incoming registration request.
*
* @param array $data
* @return \Illuminate\Contracts\Validation\Validator
*/
protected function validator(array $data)
{
return Validator::make($data, [
'name' => ['required', 'string', 'max:255'],
'email' => ['required', 'string', 'email', 'max:255', 'unique:users'],
'password' => ['required', 'string', 'min:8', 'confirmed'],
]);
}
/**
* Create a new user instance after a valid registration.
*
* @param array $data
* @return \App\User
*/
protected function create(array $data)
{
return User::create([
'name' => $data['name'],
'email' => $data['email'],
'password' => Hash::make($data['password']),
]);
}
有没有办法以合理的方式实现这一点?还有其他文件必须修改才能使其正常工作吗?
您好,
帧数
因为你想检查数据库中不应该存在活动的电子邮件,你需要使用 unique
验证规则。
https://laravel.com/docs/7.x/validation#rule-unique
use Illuminate\Validation\Rule;
在您的规则中添加此规则。
'email' => ['required', 'string', 'email', 'max:255', Rule::unique('emails',
'email')->where(function($query) {
return $query->where('is_active', TRUE);
})
],
控制器
protected function create(array $data)
{
$email = Email::create([
'email' => $data['email']
]);
return User::create([
'email_id' => $email->id,
'password' => Hash::make($data['password']),
]);
}
我是 Laravel 的新手,我被指示将字段 'email' 与 'User' 模型分开,而是使用与新的 foreign_id 对应的 foreign_id创建模型 'Email'.
用户:
public function up()
{
Schema::create('users', function (Blueprint $table) {
$table->id();
$table->integer('email_id');
$table->string('password');
$table->rememberToken();
$table->timestamps();
});
}
电子邮件:
public function up()
{
Schema::create('emails', function (Blueprint $table) {
$table->id();
$table->string('email')->unique();
$table->timestamp('email_verified_at')->nullable();
$table->boolean('is_active')->default(True);
$table->timestamps();
});
}
当然我已经在那些模型中设置了关系。
现在,当一个新用户通过表单注册时,我想检查输入的邮件地址是否已经存在于 'emails' table 中,以及可能已经找到的邮件地址是否具有 属性 'is_active' 设置为真。
目前 RegisterController 中的 'validator' 和 'create' 功能非常基础:
/**
* Get a validator for an incoming registration request.
*
* @param array $data
* @return \Illuminate\Contracts\Validation\Validator
*/
protected function validator(array $data)
{
return Validator::make($data, [
'name' => ['required', 'string', 'max:255'],
'email' => ['required', 'string', 'email', 'max:255', 'unique:users'],
'password' => ['required', 'string', 'min:8', 'confirmed'],
]);
}
/**
* Create a new user instance after a valid registration.
*
* @param array $data
* @return \App\User
*/
protected function create(array $data)
{
return User::create([
'name' => $data['name'],
'email' => $data['email'],
'password' => Hash::make($data['password']),
]);
}
有没有办法以合理的方式实现这一点?还有其他文件必须修改才能使其正常工作吗?
您好, 帧数
因为你想检查数据库中不应该存在活动的电子邮件,你需要使用 unique
验证规则。
https://laravel.com/docs/7.x/validation#rule-unique
use Illuminate\Validation\Rule;
在您的规则中添加此规则。
'email' => ['required', 'string', 'email', 'max:255', Rule::unique('emails',
'email')->where(function($query) {
return $query->where('is_active', TRUE);
})
],
控制器
protected function create(array $data)
{
$email = Email::create([
'email' => $data['email']
]);
return User::create([
'email_id' => $email->id,
'password' => Hash::make($data['password']),
]);
}