基于TOKEN的登录拦截的简单使用规则(设置token过期时间可自己使用redis进行)

1.导入依赖
在这里插入图片描述

2.先导入 token的生成和编译的工具类 JwtUtil.java(工具类放在最后了)

3.在 service业务层 登录验证成功之后 返回用户对象 通过UUID,用户id,用户名 作为依据生成 token (生成token尽量不要使用 密码这些隐秘的操作)并将生成的 token 一并返回到 前端去 如下图

在这里插入图片描述

4.前端可以取出这个 token 并通过localStorage.setItem()设置为前端页面全部可以取token值使用 如下:(这里以 ajax 请求作为实验对象 下面为 成功回调函数)
在这里插入图片描述
5.登录成功之后 别的 ajax 请求 可以用过 localStorage.getItem(“token”) 获取到 token
并将 token 设置到 请求头里面去 访问后端

在这里插入图片描述
设置请求头(在ajax请求中 加入 代码 如下):
在这里插入图片描述
这样就跟随请求传到后端了

6.后端拦截器的判断
1)首先通过 request.getHead(“token”) 获取到 token 然后判断 token 是否存在,
存在的话 分割 判断 长度是否为3 因为token由头部(header),载荷(payload),签证(signature)三个部分构成。(如果不使用redis 确认了 token存在 就等于可以放开拦截了)
2)判断之后 如果有 可以对 token进行 编译 获取到 存进去的对象(这是为了方便用uuid/id 来进行redis的处理 用来获取 token是否失效 等操作 这个自行使用redis进行就行了)

在这里插入图片描述
----------------------------------------JwtUtil 工具类------------------------------------------------------
package com.fh.util;

import com.alibaba.fastjson.JSON;
import com.auth0.jwt.JWT;
import com.auth0.jwt.JWTVerifier;
import com.auth0.jwt.algorithms.Algorithm;
import com.auth0.jwt.interfaces.DecodedJWT;

public class JwtUtil {

private static final String SECRET_KEY = "sd237#@sd!$%sdk-=";

/**
 * 加密生成token
 *
 * @param object 载体信息
 * @param <T>
 * @return
 */
public static <T> String createToken(T object) {
    try {
        final Algorithm signer = Algorithm.HMAC256(SECRET_KEY);//生成签名
        String token = JWT.create()
                .withSubject(JSON.toJSONString(object))//主题,科目
                .sign(signer);
        return token;
    } catch (Exception e) {
        e.printStackTrace();
        throw new RuntimeException(e.getMessage());
    }
}

/**
 * 解析验证token
 *
 * @param token 加密后的token字符串
 * @return
 */
public static String verifyToken(String token) {
    try {
        Algorithm algorithm = Algorithm.HMAC256(SECRET_KEY);
        JWTVerifier verifier = JWT.require(algorithm).build();
        DecodedJWT jwt = verifier.verify(token);
        return jwt.getSubject();
    } catch (Exception e) {
        throw new RuntimeException(e.getMessage());
    }
}

}

阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 4
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在Java中使用Redis来保持登录状态的常见做法是通过使用Token来实现。Token是一种用于验证用户身份和维持登录状态的令牌。 首先,用户在登录时会使用用户名和密码进行身份验证。验证成功后,可以生成一个唯一的Token,并将该Token存储在Redis中,以及与用户相关的一些其他信息,如用户名、角色等。 在用户进行其他请求时,需要验证用户的身份。此时,用户会将Token添加到请求的头部或参数中进行传递。后端服务器接收到请求后,从请求中获取Token,并将其与Redis中存储的Token进行比较。 比较的过程可以通过Redis的GET命令来实现。如果两个Token相等,则说明用户是经过身份验证的,可以继续处理后续请求。如果两个Token不相等或Redis中没有对应的Token,则说明用户的Token无效或已过期,需要重新登录。 为了保证Token的安全性,可以在生成Token时添加一定的过期时间过期时间可以通过Redis的EXPIRE命令来设置。当过期时间到达时,Redis会自动删除该Token。同时,在用户每次操作时,可以更新Token过期时间,以延长Token的生命周期,从而保持用户的登录状态。 此外,为了保证用户的安全性,还可以采用一些其他的安全措施,如使用HTTPS协议传输Token,对Token进行加密等。 总的来说,使用Java和Redis来保持登录状态可以通过生成和验证Token来实现。通过Token的比较和过期时间的控制,可以有效地验证用户身份,保持用户的登录状态,并保证用户的安全性。 ### 回答2: Java Redis token 保持登录状态是一种常见的实现用户身份认证与登录状态维持的方案。 首先,用户在成功登录后,服务器端会生成一个唯一的令牌(Token),将其存储到Redis中。令牌通常是一个随机字符串,具有一定的有效期。 然后,在用户每次访问需要登录状态的接口时,服务器会验证用户的令牌是否有效。具体的验证流程如下: 1. 服务器端接收到用户请求时,首先从请求头或请求参数中获取令牌。 2. 通过令牌,服务器从Redis中查询对应的用户信息,判断令牌是否有效。 3. 如果令牌有效,服务器会根据令牌对应的用户信息,进行后续的业务处理。 为了保持用户登录状态,需要对令牌进行管理和更新: 1. 令牌的有效期可以设置为较短的时间,比如30分钟。用户在访问接口时,可以通过每次请求都更新令牌的有效期。 2. 当用户注销或退出登录时,服务器会从Redis中删除对应的令牌,使其失效。 此外,为了增加令牌的安全性,可以进行以下操作: 1. 令牌应该是具有时效性的,并且每次验证通过后刷新令牌,防止被恶意使用。 2. 令牌的生成可以使用加密算法,如HMAC-SHA256等,以提高令牌的安全性。 3. 令牌在传输过程中应该使用HTTPS协议进行加密,避免被拦截窃取。 总之,Java Redis token 可以通过管理令牌的方式来实现用户登录状态的保持,有效防止身份伪造和非法访问。这种方案具有较好的安全性和扩展性,适用于大部分Web应用。 ### 回答3: Java Redis Token 保持登录状态是一种常见的实现方式,它通过将用户的登录信息存储在 Redis 中的 token 中,来实现用户的状态保持。 首先,在用户登录成功后,后端会生成一个 token,同时将 token 与用户信息关联存储在 Redis 中。这样,当用户进行后续的请求时,可以将 token 放入请求的头部或者参数中传递给后端。后端会通过解析该 token,查找 Redis 中对应的用户信息,判断用户是否已经登录。 当用户进行某个需要权限验证的操作时,后端会先验证 token 是否有效,即是否能够在 Redis 中找到对应的用户信息。如果 token 有效,则说明用户已登录,后端会进行相应的操作,并更新 token过期时间,延长用户的登录状态。如果 token 无效,则说明用户未登录登录过期,后端会进行相应的处理,比如返回登录失效的错误信息,要求用户重新登录。 当用户进行退出登录操作时,后端会将该 tokenRedis 中删除,从而使用户的登录状态失效。 通过使用 Redis 存储用户的登录信息,可以实现多个服务之间的共享登录状态。同时,由于 Redis 的高性能和可靠性,可以提供良好的用户登录体验和高并发支持。 需要注意的是,为了保证用户的信息安全,我们需要对 token 进行加密和签名处理,避免被恶意篡改或伪造。此外,为了减轻 Redis 的负载,可以设置 token过期时间,并定期清理 Redis过期token。 总之,通过使用 Java Redis Token 保持登录状态,可以实现用户的持续登录和权限验证,提供良好的用户体验和系统性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

notInstance

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值