gpt4 book ai didi

mysql - Laravel 5.7 中修改后的用户注册停止工作(字段 'last_name' 没有默认值,但数据完整)

转载 作者:行者123 更新时间:2023-11-29 15:14:55 24 4
gpt4 key购买 nike

我有一个 Laravel 5.7 应用程序。用户无法自行注册,必须由其他用户登录才能访问注册页面。这直到几周前才有效(我们不需要经常注册用户),但现在已经停止工作了。

这是我收到的错误(current_user@example.org 是当前登录用户的电子邮件地址的占位符,而不是新用户的地址。):

production.ERROR: SQLSTATE[HY000]: General error: 1364 Field 'last_name' doesn't have a default value (SQL: insert into `users` (`updated_at`, `created_at`) values (2020-01-15 10:09:52, 2020-01-15 10:09:52)) {"userId":1,"email":"current_user@example.org","exception":"[object] (Illuminate\\Database\\QueryException(code: HY000): SQLSTATE[HY000]: General error: 1364 Field 'last_name' doesn't have a default value (SQL: insert into `users` (`updated_at`, `created_at`) values (2020-01-15 10:09:52, 2020-01-15 10:09:52)) at /html/myproject/vendor/laravel/framework/src/Illuminate/Database/Connection.php:664, PDOException(code: HY000): SQLSTATE[HY000]: General error: 1364 Field 'last_name' doesn't have a default value at /html/myproject/vendor/laravel/framework/src/Illuminate/Database/Connection.php:458)
[stacktrace]

这是我的RegisterController。我在 create() 函数中记录了 $data 。一切(包括 $data['last_name'] 似乎都已就位:

<?php

namespace App\Http\Controllers\Auth;

use App\User;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Validator;
use Illuminate\Foundation\Auth\RegistersUsers;
use Log;

class RegisterController extends Controller
{
/*
|--------------------------------------------------------------------------
| Register Controller
|--------------------------------------------------------------------------
|
| This controller handles the registration of new users as well as their
| validation and creation. By default this controller uses a trait to
| provide this functionality without requiring any additional code.
|
*/

use RegistersUsers;

/**
* Where to redirect users after registration.
*
* @var string
*/
protected $redirectTo = '/register';

/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('auth');
}

/**
* 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, [
'first_name' => 'required|max:40',
'last_name' => 'required|max:40',
'role' => 'required|max:15',
'email' => 'required|email|max:255|unique:users',
'phone' => 'max:30',
'password' => 'required|min:6|confirmed',
]);
}

/**
* Create a new user instance after a valid registration.
*
* @param array $data
* @return User
*/
protected function create(array $data)
{
// Create flash message
$flashMessage = '<p>New user registered: ' .
$data['first_name'] .
' ' .
$data['last_name'] .
'</p>';

// Show flash message on next page view
session()->flash('flashMessage', $flashMessage);

return User::create([
'first_name' => $data['first_name'],
'last_name' => $data['last_name'],
'role' => $data['role'],
'email' => $data['email'],
'phone' => $data['phone'],
'password' => bcrypt($data['password']),
]);
}
}

这是 RegistersUsers 特征:

<?php

namespace Illuminate\Foundation\Auth;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Auth\Events\Registered;
use Log;

trait RegistersUsers
{
use RedirectsUsers;

/**
* Show the application registration form.
*
* @return \Illuminate\Http\Response
*/
public function showRegistrationForm()
{
return view('auth.register');
}

/**
* Handle a registration request for the application.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function register(Request $request)
{
$this->validator($request->all())->validate();

event(new Registered($user = $this->create($request->all())));

// $this->guard()->login($user);

return $this->registered($request, $user)
?: redirect($this->redirectPath());
}

/**
* Get the guard to be used during registration.
*
* @return \Illuminate\Contracts\Auth\StatefulGuard
*/
protected function guard()
{
return Auth::guard();
}

// registered() is empty
}

最佳答案

打开您的 Model User.php 并添加此行 protected $guarded = []; 或在 $fillable 数组中包含 last_name。我希望这会有所帮助。

关于mysql - Laravel 5.7 中修改后的用户注册停止工作(字段 'last_name' 没有默认值,但数据完整),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59748630/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com