使用jwt生成token

这是jwt 官网 https://jwt.io/,有兴趣撸友的可以看一下。

在官网中可以看到,给了一个示例,左边的token 解码以后,就会由youy右边的三部分组成,分别是 头,有效载荷,验证签名。

头(包含算法和类型),有效载荷这个就比较核心了,用户可以在这里添加自己想添加的信息,包含token过期时间等。详情请参考这位撸友大佬https://blog.csdn.net/csdn_blog_lcl/article/details/73485463,验证签名是由头和有效载荷组成,详情查看https://www.cnblogs.com/wwlww/p/8413334.html大佬。

在官网中向下可以看见

点击可以进入

可以看到有如下一下文档可以参考

点击helloworl example 参考官方文档的示例吧

 

下面就介绍我自己集成的

使用maven

pom.xml

 

<dependency>
   <groupId>com.auth0</groupId>
   <artifactId>java-jwt</artifactId>
   <version>3.4.0</version>
</dependency>

 

public interface TokenService {

    /**
     * 生成用户token
     * @param member
     * @return
     */
    String getToken(Member member);
}
@Service
public class TokenServiceImpl implements TokenService{


    /**
     * 获取用户token
     * @param member
     * @return
     */
    public String getToken(Member member) {
        String token="";
        token= JWT.create().withAudience(String.valueOf(member.getId()))
                .sign(Algorithm.HMAC256(member.getPassword()));
        return token;
    }
}

@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface PassToken {
    boolean required() default true;
}
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface UserLoginToken {
    boolean required() default true;
}

public class AuthenticationInterceptor implements HandlerInterceptor {

   @Autowired
   MemberService memberService;

   @Override
   public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse,
         Object object) throws Exception {
      String token = httpServletRequest.getHeader("token");// 从 http 请求头中取出
      // 如果不是映射到方法
      if (!(object instanceof HandlerMethod)) {
         return true;
      }
      HandlerMethod handlerMethod = (HandlerMethod) object;
      Method method = handlerMethod.getMethod();
      // 检查是否有passtoken注释,有则跳过认证
      if (method.isAnnotationPresent(PassToken.class)) {
         PassToken passToken = method.getAnnotation(PassToken.class);
         if (passToken.required()) {
            return true;
         }
      }
      // 检查有没有需要用户权限的注解
      if (method.isAnnotationPresent(UserLoginToken.class)) {
         UserLoginToken userLoginToken = method.getAnnotation(UserLoginToken.class);
         if (userLoginToken.required()) {
            // 执行认证
            if (token == null) {
               //显示错误信息
               return false;
            }
            // 获取 token 中的 user id
            String memberId;
            try {
               memberId = JWT.decode(token).getAudience().get(0);
            } catch (JWTDecodeException j) {
               j.printStackTrace();
               //显示错误信息
               return false;
            }
            Member member = memberService.selectById(memberId);
            if (member == null) {
               //显示错误信息
               return false;
            }
            // 验证 token
            JWTVerifier jwtVerifier = JWT.require(Algorithm.HMAC256(member.getPassword())).build();
            try {
               jwtVerifier.verify(token);
            } catch (JWTVerificationException e) {
               e.printStackTrace();
               //显示错误信息
               return false;
            }
            httpServletRequest.setAttribute("member", member);
            return true;
         }else{
            if (token != null) {
               String memberId = null;
               try {
                  memberId = JWT.decode(token).getAudience().get(0);
               } catch (JWTDecodeException j) {
               }
               Member member = memberService.selectById(memberId);
               if(member != null){
                  // 验证 token
                  JWTVerifier jwtVerifier = JWT.require(Algorithm.HMAC256(member.getPassword())).build();
                  try {
                     jwtVerifier.verify(token);
                  } catch (JWTVerificationException e) {
                  }
                  httpServletRequest.setAttribute("member", member);
               }
            }
         }
      }
      return true;
   }

   @Override
   public void postHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o,
         ModelAndView modelAndView) throws Exception {

   }

   @Override
   public void afterCompletion(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse,
         Object o, Exception e) throws Exception {
   }
   

    

}
  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
使用jwt生成token的方法如下: 1. 导入jwt库:首先,需要导入jwt库以便使用其中的相关方法。 2. 定义payload:根据需要,在生成token之前定义一个payload,即包含token中的一些信息,例如用户ID、过期时间等。 3. 设置密钥:生成token使用的密钥是保证token的安全性的关键。你需要设置一个密钥,可以是一个随机字符串。 4. 调用jwt库的generate_token方法:使用jwt库中的generate_token方法,传入payload和密钥,即可生成token。 下面是一个示例代码: ```python import jwt def generate_token(payload, secret_key): token = jwt.encode(payload, secret_key) return token # 示例用法 payload = {'user_id': 1, 'exp': 3600} # 设置用户ID和过期时间(单位:秒) secret_key = 'my_secret_key' # 设置密钥 token = generate_token(payload, secret_key) ``` 在示例代码中,我们定义了一个generate_token函数,它接受payload和密钥作为参数,并使用jwt库中的encode方法生成token。注意,生成token是一个字符串。 请注意,这只是一个简单的示例代码,实际应用中可能需要更多的逻辑来处理用户认证和授权等问题。具体使用jwt生成token的方式可能会因不同的框架或库而略有不同,你可以根据你所使用的具体情况进行适当的调整。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [使用JWT生成Token,并实现Token刷新API](https://blog.csdn.net/xili2532/article/details/122218117)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值