首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Laravel JWT身份验证将令牌过期设置为1天。

Laravel JWT身份验证将令牌过期设置为1天。
EN

Stack Overflow用户
提问于 2022-07-19 12:08:07
回答 1查看 365关注 0票数 0

我有API Laravel项目,我使用JWT身份验证,在respondWithToken()中,我将getTTL() * 60更改为getTTL() * 1440,在大约1小时后仍然返回401 Unauthorized错误。

这是控制器函数

代码语言:javascript
运行
复制
public function login(Request $request)
{
    $credentials = $request->only(['email', 'password']);

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

    $response = [];

    array_push($response, $this->respondWithToken($token), $this->me());

    return response()->json($response);
}

/**
 * Get the authenticated User.
 *
 * @return \Illuminate\Http\JsonResponse
 */

public function me()
{
    return response()->json(auth('admin_api')->user());
}

/**
 * Log the user out (Invalidate the token).
 *
 * @return \Illuminate\Http\JsonResponse
 */

public function logout()
{
    auth('admin_api')->logout();

    return response()->json(['message' => 'Successfully Logged Out']);
}

/**
 * Refresh a token.
 *
 * @return \Illuminate\Http\JsonResponse
 */

public function refresh()
{
    return $this->respondWithToken(auth('admin_api')->refresh());
}

/**
 * Get the token array structure.
 *
 * @param  string $token
 *
 * @return \Illuminate\Http\JsonResponse
 */

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

public function register(Request $request)
{
    $validator = Validator::make($request->all(), [
        'name' => 'required|string|between:2,100',
        'email' => 'required|string|email|max:100|unique:users',
        'password' => 'required|string|min:8'
    ]);

    if ($validator->fails()) {
        return response()->json($validator->errors()->toJson(), 400);
    }

    $user = User::create(
        array_merge(
            $validator->validated(),
            ['password' => bcrypt($request->password)]
        )
    );

    return response()->json([
        'message' => 'Admin Registered Successfully',
        'admin' => $user
    ], 201);
}

有人能帮我认识到如何解决这个问题吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-07-19 13:53:37

我使用的是jwt配置文件:

  1. 发布配置文件(如果还没有)
代码语言:javascript
运行
复制
php artisan vendor:publish --provider="PHPOpenSourceSaver\JWTAuth\Providers\LaravelServiceProvider"
  1. JWT_TTL .env文件中以分钟为单位设置.env
代码语言:javascript
运行
复制
JWT_TTL=1440 #set expiration to 1 day
  1. 从配置文件读取过期时间
代码语言:javascript
运行
复制
protected function respondWithToken(string $token): JsonResponse
    {
        return response()->json([
            'access_token' => $token,
            'token_type' => 'bearer',
            'expires_in' => config('jwt.ttl') * 60,
        ]);
    }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73036619

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档