Mysql不接受表单输入Laravel 5.2

时间:2016-06-05 08:46:52

标签: php mysql laravel

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>

1 个答案:

答案 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'];
}