一、如果用来认证的用户表不是默认的users怎么办?
1,在config/auth.php中新建一个provider
'providers' => [ 'users' => [ 'driver' => 'eloquent', 'model' => App\User::class, ], 'store_admins' => [ 'driver' => 'eloquent', 'model' => App\Models\StoreUser::class, ], ],
2,修改guards中api的provider为刚才新建的那个。
'guards' => [ 'web' => [ 'driver' => 'session', 'provider' => 'users', ], 'api' => [ 'driver' => 'passport', 'provider' => 'store_admins', ], ],
那个Model : StoreUser要自己建。
二、如果用来认证的字段不是默认的email怎么办?
在对应的model文件中添加一个方法。
/** * customize username field * * @param $identifier * @return mixed */ public function findForPassport($identifier) { return self::orWhere('login_name', $identifier)->first(); }这样,就会以login_name作为用户名来验证用户登录。
三、如果用户表的主键不是int型,而是uuid怎么办?
需要修改oauth_access_tokens表中的user_id字段的类型改成uuid.
创建个migration
php artisan make:migration alter_table_oauth_access_tokens
可以先删除user_id,再建一个新的user_id,类型是uuid.
/** * Run the migrations. * * @return void */ public function up() { Schema::table('oauth_access_tokens', function (Blueprint $table) { $table->dropColumn('user_id'); }); Schema::table('oauth_access_tokens', function (Blueprint $table) { $table->uuid('user_id')->index()->nullable(); }); }
-完-