Laravelでユーザー登録時に、2つのテーブルにデータを登録したい。
前提・実現したいこと
Laravel5.5を使って、システム開発を行っています。
まずユーザー登録部分の実装を進めています。
認証機能は php artisan make:auth で追加したものをベースに実装しています。
通常、認証に使用するテーブルは users で、それに紐付く形で Userという Illuminate\Foundation\Auth\User を継承したモデルを使用すると思います。
今回はそのまま使用するのではなく
・別の認証テーブルを使用する
・ユーザー登録時に、もうひとつのテーブルにも情報を登録する
という部分で変更が発生しています。
具体的には
・ユーザー情報テーブル:account
⇒Modelを継承したAccountクラスを用意
・ユーザー認証テーブル:account_login
⇒Illuminate\Foundation\Auth\Userを継承したAccountLoginクラスを用意
し、ユーザー登録時にトランザクションを張って
↓accountテーブルにデータを登録。AUTO_INCREMENTでID発行。
↓account_loginテーブルにデータ(認証情報)を登録。その際にaccountで発行されたIDも登録。
という流れでユーザー登録を行いたいと考えています。
発生している問題・エラーメッセージ
ユーザー登録のフォームにデータを入力し「登録」ボタンを押したら
Illuminate \ Database \ Eloquent \ MassAssignmentException corp_cd
というエラーが発生しました。
該当のソースコード
App\Http\Controllers\Auth\RegisterController
PHP7.1
1 protected function create(array $data) 2 { 3 DB::beginTransaction(); 4 try { 5 $result = Account::create([ 6 'corp_cd' => '00001', 7 'login_account_name' => $data['login_account_name'], 8 'account_type_cd' => $data['account_type_cd'], 9 'account_name' => $data['account_name'], 10 'account_name_kana' => $data['account_name_kana'], 11 'mail_address' => $data['mail_address'], 12 ]); 13 14 $last_account_id = $result->account_id; 15 16 $result = AcountLogin::create([ 17 'corp_cd' => '00001', 18 'account_id' => $last_account_id, 19 'login_account_name' => $data['login_account_name'], 20 'password' => bcrypt($data['password']), 21 'password_update_time' => date('Y-m-d H:i:s'), 22 ]); 23 24 DB::commit(); 25 return $result; 26 } catch (\PDOException $e){ 27 DB::rollBack(); 28 return false; 29 } 30 }
試したこと
AccountLoginには
protected $fillable = [ 'corp_cd', ];
で設定されていたので、Accountにも同じものを追加したところ
Type error: Argument 1 passed to Illuminate\Auth\SessionGuard::login() must be an instance of Illuminate\Contracts\Auth\Authenticatable, boolean given
となりました。
⇒Illuminate\Foundation\Auth\Userを継承していないから使えない?
AccountにもIlluminate\Foundation\Auth\Userを継承させた場合
Type error: Argument 1 passed to Illuminate\Auth\SessionGuard::login() must implement interface Illuminate\Contracts\Auth\Authenticatable, boolean given
となりました。
補足情報(FW/ツールのバージョンなど)
◆動作環境
・Windows10 Pro 64bit
・Apache2.4
・PHP7.1
・Laravel5.5
・MySQL5.7
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/02/20 16:12
2018/02/20 22:36
2018/02/22 02:27