larval5.7安装jwt使用

将包添加到composer.json

"require": {
    ...
    "tymon/jwt-auth": "1.0.0-rc.3"
}

然后按命令更新composer

composer update

设置配置

生成密钥
php artisan jwt:secret
发布配置文件
php artisan vendor:publish --provider="Tymon\JWTAuth\Providers\LaravelServiceProvider"
打开app.php并添加以下行

在’aliases array’数组中

'JWTAuth'=> Tymon\JWTAuth\Facades\JWTAuth::class,
'JWTFactory'=> Tymon\JWTAuth\Facades\JWTFactory::class,
更新用户模型

打开User.php并为模型实现JWTSubject

use Tymon\JWTAuth\Contracts\JWTSubject; class User extends Authenticatable implements JWTSubject 

并在模型中添加2个方法(在未完成的官方指南中阅读有关这些功能的更多信息)

public function getJWTIdentifier(){
    return $ this-> getKey(); } public function getJWTCustomClaims(){ return []; } 
更新配置auth.php

打开config/auth.php并将API的保护驱动程序更改为’jwt’(默认为令牌)

'guards'=> [ 
    ...
    'api'=> [
        'driver'=>'jwt',
        'provider'=>'users', ], ], 
创建登录控制器

创建controller用于login、logout、refresh等

<?php

namespace App\Http\Controllers\Auth; use Illuminate\Support\Facades\Auth; use App\Http\Controllers\Controller; class JwtAuthController extends Controller { /** * Create a new AuthController instance. * * * @return void */ public function __construct() { $this->middleware('jwt.auth', ['except' => ['login']]); // 另外关于上面的中间件,官方文档写的是『auth:api』 // 但是我推荐用 『jwt.auth』,效果是一样的,但是有更加丰富的报错信息返回 } /** * Get a JWT via given credentials. * * @return \Illuminate\Http\JsonResponse */ public function login() { $credentials = request(['email', 'password']); if (! $token = auth('api')->attempt($credentials)) { return response()->json(['error' => 'Unauthorized'], 401); } return $this->respondWithToken($token); } /** * Get the authenticated User. * * @return \Illuminate\Http\JsonResponse */ public function me() { return response()->json(auth('api')->user()); } /** * Log the user out (Invalidate the token). * * @return \Illuminate\Http\JsonResponse */ public function logout() { auth('api')->logout(); return response()->json(['message' => 'Successfully logged out']); } /** * Refresh a token. * 刷新token,如果开启黑名单,以前的token便会失效。 * 值得注意的是用上面的getToken再获取一次Token并不算做刷新,两次获得的Token是并行的,即两个都可用。 * @return \Illuminate\Http\JsonResponse */ public function refresh() { return $this->respondWithToken(auth('api')->refresh()); } /** * Get the token array structure. * * @param string $token * * @return \Illuminate\Http\JsonResponse */ protected function respondWithToken($token) { return response()->json([ 'access_token' => $token, 'token_type' => 'bearer', 'expires_in' => auth('api')->factory()->getTTL() * 60 ]); } } 
创建路由

打开routes/api.php然后添加一些路由

Route::group(['prefix' => 'auth'], function () { Route::post('login', 'Auth\\JwtAuthController@login'); Route::post('logout', 'Auth\\JwtAuthController@logout'); Route::post('refresh', 'Auth\\JwtAuthController@refresh'); Route::post('me', 'Auth\\JwtAuthController@me'); }); 

然后在标头请求中添加“Authorization:Bearer {token}”

如果你想捕获异常 在你的app/Exceptions/Handler.php中捕获’render’函数中的错误。

use Symfony\Component\HttpKernel\Exception\UnauthorizedHttpException; …… if ($exception instanceof UnauthorizedHttpException) { $preException = $exception->getPrevious(); if ($preException instanceof \Tymon\JWTAuth\Exceptions\TokenExpiredException) { return response()->json(['error' => 'TOKEN_EXPIRED']); } else if ($preException instanceof \Tymon\JWTAuth\Exceptions\TokenInvalidException) { return response()->json(['error' => 'TOKEN_INVALID']); } else if ($preException instanceof \Tymon\JWTAuth\Exceptions\TokenBlacklistedException) { return response()->json(['error' => 'TOKEN_BLACKLISTED']); } if ($exception->getMessage() === 'Token not provided') { return response()->json(['error' => 'Token not provided']); } } 

猜你喜欢

转载自www.cnblogs.com/zhanghuilong/p/11718020.html