jwt laravel


《jwt laravel》

一、解决方案简述

在Laravel项目中使用JWT(JSON Web Token)可以实现安全可靠的用户身份验证。通过JWT,客户端能够携带令牌与服务器进行交互,而无需依赖传统的基于会话的认证方式。它有助于构建无状态的API,方便前后端分离项目的开发,并且能有效保障数据的安全性。

二、基于Dingo JWT包实现JWT认证

1. 安装

在composer.json文件中添加对dingo/api和tymon/jwt - auth包的依赖:
json
"require": {
"php": "^7.3|^8.0",
// 其他依赖
"tymon/jwt-auth": "^1.0"
}

然后执行composer update命令安装。

2. 配置

发布JWT - Auth配置文件:
bash
php artisan vendor:publish --provider="TymonJWTAuthProvidersLaravelServiceProvider"

修改.env文件中的密钥:
properties
JWT_SECRET=your_jwt_secret_key

3. 用户登录示例代码

app/Http/Controllers/AuthController.php中编写登录逻辑:
```php
namespace AppHttpControllers;
use IlluminateHttpRequest;
use TymonJWTAuthFacadesJWTAuth;
use AppModelsUser;

class AuthController extends Controller
{
public function login(Request $request)
{
$credentials = $request->only('email', 'password');
if (! $token = JWTAuth::attempt($credentials)) {
return response()->json(['error' => 'invalid_credentials'], 400);
}
return response()->json(compact('token'));
}
}
```

三、基于自定义中间件的方式

创建一个名为JwtMiddleware的中间件:
php
php artisan make:middleware JwtMiddleware

app/Http/Middleware/JwtMiddleware.php中编写代码:
```php
namespace AppHttpMiddleware;
use Closure;
use TymonJWTAuthFacadesJWTAuth;
use TymonJWTAuthExceptionsTokenInvalidException;
use TymonJWTAuthExceptionsTokenExpiredException;

class JwtMiddleware
{
public function handle($request, Closure $next)
{
try {
JWTAuth::parseToken()->authenticate();
} catch (TokenInvalidException $e) {
return response()->json(['status' => 'Token is Invalid'], 401);
} catch (TokenExpiredException $e) {
return response()->json(['status' => 'Token is Expired'], 401);
} catch (TymonJWTAuthExceptions.JWTException $e) {
return response()->json(['status' => 'Token error'], 500);
}

    return $next($request);
}

}
```
再将这个中间件应用到需要保护的路由上。

以上两种思路都能在Laravel项目中很好地实现JWT功能,可根据项目需求选择合适的方式。

Image

1. 本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!如有侵权请邮件联系客服!cheeksyu@vip.qq.com
2. 本站不保证所提供下载的资源的准确性、安全性和完整性,资源仅供下载学习之用!如有链接无法下载、失效或广告,请联系客服处理!
3. 您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源!如用于商业或者非法用途,与本站无关,一切后果请用户自负!
4. 如果您也有好的资源或教程,您可以投稿发布,成功分享后有积分奖励和额外收入!
5.严禁将资源用于任何违法犯罪行为,不得违反国家法律,否则责任自负,一切法律责任与本站无关

源码下载