Аутентификация с использованием JWT (JSON Web Token) в Laravel (PHP) - PullRequest
1 голос
/ 08 мая 2019

Я пытаюсь реализовать аутентификацию в Laravel, используя tymondesigns / jwt-auth (JSON Web Token).

Вот некоторый код из моего файла конфигурации auth.php:

...

'defaults' => [
    'guard' => 'api',
    'passwords' => 'users',
],

'guards' => [
    'api' => [
        'driver' => 'jwt',
        'provider' => 'users',
    ],
],

'providers' => [
    'users' => [
        'driver' => 'eloquent',
        'model' => App\User::class,
    ],
],
...

Вот один маршрут из моего файла маршрутов / api.php для входа:

Route::post('/login', 'AuthController@login');

Вот мой файл AuthController.php:

class AuthController extends Controller
{

    public function login() {
        // $credentials = request(['email', 'password']);
        $credentials = ["email" => "test@test.te", "password" => "test123"];

        if (! ($token = auth()->attempt($credentials))) {
            return response()->json(['error' => 'Unauthorized'], 401);
        }

        return $this->respondWithToken($token);
    }

    protected function respondWithToken($token)
    {
        return response()->json([
            'access_token' => $token,
            'token_type'   => 'bearer',
            'expires_in'   => auth()->factory()->getTTL() * 60
        ]);
    }

    ...
}

А вот мой класс модели User.php:

<?php

namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Tymon\JWTAuth\Contracts\JWTSubject;

class User extends Authenticatable implements JWTSubject
{
    use Notifiable;

    protected $table = 'user';

    protected $primaryKey = 'id';
    public $incrementing = true;
    public $timestamps = false;

    protected $hidden = [
        'password', 'remember_token',
    ];

    ...

    public function getJWTIdentifier()
    {
        return $this->getKey();
    }

    public function getJWTCustomClaims()
    {
        return [];
    }

    public function setPasswordAttribute($password)
    {
        if ( !empty($password) ) {
            $this->attributes['password'] = bcrypt($password);
        }
    }

}

auth()->attempt($credentials) в методе AuthController @ login возвращает false, но я 'Я уверен, что учетные данные правильно в базе данных.Я попытался очистить кеш, но все равно не повезло, и я не могу заставить аутентификацию работать.Любая причина, почему это не работает?

...