PHP和Laravel 5.2的新手。我用php artisan make:auth创建了一个用户表,但是想要在我的数据库中再添加两列。我能够在数据库中添加列,但是当我注册新用户时,它接受除mysql中的first_name和last_name之外的所有内容,它们都是空白的。我不明白我错过了什么?
Schema::create('users', function (Blueprint $table) {
$table->increments('id');
$table->string('first_name');
$table->string('last_name');
$table->string('email')->unique();
$table->string('avatar')->default('default.jpg');
$table->string('password');
$table->rememberToken();
$table->timestamps();
});
我的AuthController文件
protected function validator(array $data)
{
return Validator::make($data, [
'first_name' => 'required|max:255',
'last_name' => 'required|max:255',
'email' => 'required|email|max:255|unique:users',
'password' => 'required|min:6|confirmed',
]);
}
protected function create(array $data)
{
return User::create([
'first_name' => $data['first_name'],
'last_name' => $data['last_name'],
'email' => $data['email'],
'password' => bcrypt($data['password']),
]);
register.blade
上first_name的表单输入示例<div class="form-group{{ $errors->has('first_name') ? ' has-error' : '' }}">
<label class="col-md-4 control-label">First Name</label>
<div class="col-md-6">
<input type="text" class="form-control" name="first_name" value="{{ old('first_name') }}">
@if ($errors->has('first_name'))
<span class="help-block">
<strong>{{ $errors->first('first_name') }}</strong>
</span>
@endif
</div>
</div>
答案 0 :(得分:1)
正如@Sid所说,这些字段需要是可批量分配的,这在文档中有描述:
您也可以使用create方法将新模型保存在单个模型中 线。 [...]在此之前,您需要在模型上指定可填充或保护属性,因为所有Eloquent模型都可以防止批量分配。
来自https://laravel.com/docs/5.2/eloquent#mass-assignment
class Flight extends Model
{
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = ['name'];
}