使用Laravel/Passport 进行API认证二

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();
    });
}


-完-