嗨,我在前端使用角度js,在后端使用带有tymon jwt库的卫星和laravel.我正在使用jwt身份验证.我想在我的网络应用程序中记住我的功能.我看到’ttl’在laravel’config / jwt.php中设置令牌的到期时间.

|--------------------------------------------------------------------------

| JWT time to live

|--------------------------------------------------------------------------

| Specify the length of time (in minutes) that the token will be valid for.

| Defaults to 1 hour

'ttl' => 60,

默认情况下,它将是1小时.但是如果用户点击在登录时记住我,我想动态地将其更改为1周.我该如何动态更改它.谢谢.

解决方法:

您可以将exp添加为自定义声明,如下所示:

$token = JWTAuth::attempt($credentials, ['exp' => Carbon\Carbon::now()->addDays(7)->timestamp]);

上面的代码创建了一个在7天后到期的令牌.你不必使用Carbon它只需要一个Unix时间戳,我在这里使用Carbon是为了简单,因为它内置在Laravel中.

标签:php,angularjs,jwt,laravel-5

来源: https://codeday.me/bug/20190717/1487458.html

嗨,我在前端使用角度js,在后端使用带有tymon jwt库的卫星和laravel.我正在使用jwt身份验证.我想在我的网络应用程序中记住我的功能.我看到’ttl’在laravel’config / jwt.php中设置令牌的到期时间./*|--------------------------------------------------------------------------| JWT...
前后端分离的项目中采用 jwt 作为接口的安全机制会遇到 jwt 过期 的问题。 jwt 中可以 设置 过期 时间 ,即使是 设置 成一个月,但可能用户正上一秒还在使用,下一秒 jwt 过期 被叫去重新登录,这是不能接受的,所以需要有处理 jwt 过期 的机制。 在这个问题上比较常用的做法是采用双 token ——access token 和refresh token 来处理,access token 用户授权,refresh token 用于前者 过期 后获取新的access token 。 我在这里记录我单 token 方案的思路。 用户登录时生成t
package com.zhjt.zhdataexchange.utils; import io.jsonweb token .*; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; import jav...
在使用 laravel 时候 摒弃了自带的Auth和passport。主要原因是项目前后端分离,后端写api接口,另外email不做登录选项,password和用户信息存储分开存。在使用 JWT 过程中遇到很多的坑。坑1 不能用 JWT Auth静态调用直接 public function xxx ( JWT Auth $ jwt ){ $ jwt -...
最近在做一个app,登录验证是用的 jwt token 验证,今天来记录一下...... 我的本次实例操作主要参考了下面资料 https:// jwt .io/introduction/ https://blog.csdn.net/jikeehuang/article/details/51488020 https://www.cnblogs.com/ganchuanpu/archive/2017/...
Date expiresDate = new Date(System.currentTimeMillis() + expire_time);// expire_time为 token 有效时长, 单位毫秒 错误顺序示例: Jwt Builder r...
Laravel 中使用 JWT ,您可以使用tymondesigns/ jwt -auth包来生成和验证 JWT 。要 设置 JWT 过期 时间 ,您需要在 Laravel 配置文件中定义一个默认的 过期 时间 ,并在生成 JWT 时覆盖该默认值。以下是如何在 Laravel 设置 JWT 过期 时间 : 1. 首先,您需要在config/ jwt . php 文件中定义默认的 过期 时间 : ``` php ' jwt ' => [ 'ttl' => env(' JWT _TTL', 60), // 默认 过期 时间 为60分钟 2. 在生成 JWT 时,您可以使用` JWT Factory`类来覆盖默认的 过期 时间 。例如: ``` php use Tymon\ JWT Auth\Facades\ JWT Auth; use Tymon\ JWT Auth\Exceptions\ JWT Exception; $payload = [ 'user_id' => 1, 'exp' => Carbon\Carbon::now()->addHours(2)->timestamp, // 过期 时间 为2小时 try { $ token = JWT Auth::fromUser($user, $payload); } catch ( JWT Exception $e) { // 处理异常 在上面的例子中,我们使用`Carbon`类来计算 过期 时间 ,并将其作为payload的一部分传递给`fromUser`方法。 3. 您还可以通过在路由或控制器方法上使用` jwt .auth`中间件来验证 JWT 并自动处理 过期 时间 。例如: ``` php Route::get('/api/user', function () { // 当前用户必须通过 JWT 身份验证 })->middleware(' jwt .auth'); 在上面的代码中,如果 JWT 过期 ,` jwt .auth`中间件会自动抛出` Token ExpiredException`异常。 总之,您可以使用`tymondesigns/ jwt -auth`包轻松地在 Laravel 中生成和验证 JWT ,并使用默认或自定义的 过期 时间 来控制 JWT 的有效期。