1、若是用来认证的用户表不是默认的users怎么办?php
1,在config/auth.php中新建一个providerweb
'providers' => [ 'users' => [ 'driver' => 'eloquent', 'model' => App\User::class, ], 'store_admins' => [ 'driver' => 'eloquent', 'model' => App\Models\StoreUser::class, ], ],
2,修改guards中api的provider为刚才新建的那个。api
'guards' => [ 'web' => [ 'driver' => 'session', 'provider' => 'users', ], 'api' => [ 'driver' => 'passport', 'provider' => 'store_admins', ], ],
那个Model : StoreUser要本身建。session
2、若是用来认证的字段不是默认的email怎么办?ide
在对应的model文件中添加一个方法。ui
/** * customize username field * * @param $identifier * @return mixed */ public function findForPassport($identifier) { return self::orWhere('login_name', $identifier)->first(); }这样,就会以login_name做为用户名来验证用户登陆。
3、若是用户表的主键不是int型,而是uuid怎么办?spa
须要修改oauth_access_tokens表中的user_id字段的类型改为uuid.token
建立个migrationio
php artisan make:migration alter_table_oauth_access_tokens
table
能够先删除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(); }); }
-完-