当前位置: 首页 > news >正文

东阿县城市建设局网站推荐几个好看的网站

东阿县城市建设局网站,推荐几个好看的网站,南京网站制作有限公司,隆力奇会员管理系统文章目录 Spring Boot 集成JWT实现Token验证详解一、引言二、JWT和Token基础1、什么是Token2、什么是JWT3、JWT的结构4、JWT的工作原理 三、集成JWT1、引入JWT依赖2、创建Token工具类3、创建拦截器4、注册拦截器 四、总结 Spring Boot 集成JWT实现Token验证详解 一、引言 在现…

文章目录

  • Spring Boot 集成JWT实现Token验证详解
    • 一、引言
    • 二、JWT和Token基础
      • 1、什么是Token
      • 2、什么是JWT
      • 3、JWT的结构
      • 4、JWT的工作原理
    • 三、集成JWT
      • 1、引入JWT依赖
      • 2、创建Token工具类
      • 3、创建拦截器
      • 4、注册拦截器
    • 四、总结

Spring Boot 集成JWT实现Token验证详解

一、引言

在现代Web应用开发中,随着前后端分离和微服务架构的流行,传统的基于Cookie和Session的身份验证方式已经逐渐被基于Token的验证方式所取代。JWT(Json Web Tokens)作为一种轻量级的身份验证机制,因其简单、安全且易于使用的特性而广受欢迎。本文将详细介绍什么是JWT,什么是Token,以及如何在Spring Boot项目中集成JWT来实现Token验证。

二、JWT和Token基础

1、什么是Token

Token是一种令牌,它在用户登录后由服务器生成并返回给客户端,客户端在随后的请求中将Token附在HTTP请求头中,以此来验证用户的身份。Token通常包含了用户的身份信息和一些其他的元数据。

2、什么是JWT

JWT(Json Web Tokens)是一个开放标准(RFC 7519),它定义了一种紧凑且自包含的方式,用于在双方之间以JSON对象的形式安全地传输信息。每个Token都是经过数字签名的,因此可以被验证和信任。JWT可以使用秘密(对称加密)或使用RSA或ECDSA的公钥/私钥对(非对称加密)进行签名。

3、JWT的结构

JWT由三部分组成,用点.分隔:

  • Header(头部):通常包含Token的类型(即JWT)和所使用的签名算法,如HMAC SHA256或RSA。
  • Payload(负载):包含所要传递的信息。负载可以包含多个声明(Claims),声明是关于实体(通常是用户)和其他数据的声明。
  • Signature(签名):用于验证消息在传输过程中未被篡改,并且,对于使用私钥签名的Token,还可以验证发送者的身份。

4、JWT的工作原理

  1. 用户使用用户名和密码登录。
  2. 服务器验证用户的凭据,并创建一个包含用户信息和其他需要的数据的JWT。
  3. 服务器将JWT发送给客户端。
  4. 客户端在随后的每个请求中将JWT放在HTTP请求头中发送给服务器。
  5. 服务器验证JWT的有效性,如果有效,则允许用户访问资源。

在这里插入图片描述

三、集成JWT

1、引入JWT依赖

在Spring Boot项目的pom.xml文件中引入JWT依赖。

<dependency><groupId>com.auth0</groupId><artifactId>java-jwt</artifactId><version>3.10.3</version>
</dependency>
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency>

2、创建Token工具类

创建一个工具类TokenUtil,用于生成和验证JWT Token。

import com.auth0.jwt.JWT;
import com.auth0.jwt.algorithms.Algorithm;
import com.auth0.jwt.exceptions.JWTVerificationException;
import com.auth0.jwt.interfaces.DecodedJWT;
import com.auth0.jwt.interfaces.JWTVerifier;import java.util.Date;
import java.util.HashMap;
import java.util.Map;@Component
public class TokenUtil {private static final String SECRET = "your-secret"; // 密钥,生产环境应保持安全public String createToken(String username) {try {Date expireDate = new Date(System.currentTimeMillis() + 3600 * 1000); // 设置Token过期时间return JWT.create().withIssuer("auth0").withClaim("username", username).withExpiresAt(expireDate).sign(Algorithm.HMAC256(SECRET));} catch (Exception exception) {throw new RuntimeException("Token创建失败");}}public Map<String, String> verifyToken(String token) {try {JWTVerifier verifier = JWT.require(Algorithm.HMAC256(SECRET)).withIssuer("auth0").build();DecodedJWT jwt = verifier.verify(token);return jwt.getClaims();} catch (JWTVerificationException exception) {throw new RuntimeException("Token验证失败");}}
}

3、创建拦截器

创建一个拦截器TokenInterceptor,用于在请求中验证Token。

import org.springframework.web.servlet.HandlerInterceptor;import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;@Component
public class TokenInterceptor implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {String token = request.getHeader("Authorization");if (token != null && !token.isEmpty()) {TokenUtil tokenUtil = new TokenUtil();Map<String, String> claims = tokenUtil.verifyToken(token);if (claims != null) {return true;}}response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);response.getWriter().write("Unauthorized");return false;}
}

4、注册拦截器

将拦截器注册到Spring Boot中。

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;@Configuration
public class WebConfig implements WebMvcConfigurer {@Autowiredprivate TokenInterceptor tokenInterceptor;@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(tokenInterceptor).addPathPatterns("/**").excludePathPatterns("/login", "/public/**");}
}

四、总结

通过上述步骤,我们已经在Spring Boot项目中成功集成了JWT,实现了Token的生成和验证。这种基于Token的身份验证机制不仅适用于单体应用,也适用于微服务架构,为现代Web应用提供了一种灵活、安全的身份验证解决方案。希望本文能帮助你更好地理解和实现JWT Token验证。


版权声明:本博客内容为原创,转载请保留原文链接及作者信息。

参考文章

  • CSDN博客 - springboot整合token
  • 腾讯云开发者社区 - Spring Boot 如何集成JWT实现Token验证
http://www.yayakq.cn/news/127907/

相关文章:

  • 家政公司网站怎么做网站的设计与开发的图片
  • 山西山西省建设厅网站首页seo加盟代理
  • 绵阳做网站公司百度百度网址大全
  • 市场营销平台如何进行优化
  • 网站做的简单是什么意思跨境电商app
  • 手机网站跳转怎么做外贸怎么做站外推广
  • 成都网站建设g冠辰网站建设员是做什么的
  • 域名备案不是网站公司做的动漫制作专业的高职实训室
  • 何做百度推广网站私人做的不错的网站
  • 做网站看百度脸色全能网站建设完全自学
  • 茶山东莞网站建设计算机程序网站开发是什么
  • 做网站 营业执照互联网络推广
  • 服务器怎样做网站呢网站建设现状
  • 有哪些推广网站四川省建设厅新网站
  • 各大网站推荐静态网站后台
  • 哪个网站能买到做披萨的芝士正宗设计工作室效果图
  • 北京it公司排名国外网站seo免费
  • 广西网站建设开发团队个人网页设计说明书的设计目的
  • 好网站设计公司网站制作过程内容
  • 网站开发技术支持长沙制作公园仿竹围栏厂家电话
  • 济南网站建设群宣传海报用什么软件做
  • 保山市建设厅网站wordpress 开发者模式
  • 珠海网站系统建设项目中英文网站模板下载
  • 怎么做网站后台管理系统长沙网站开发流程
  • 做外贸哪个网站看外汇wordpress首页中不显示文章
  • 某学校网站建设方案论文讯美智能网站建设
  • 安阳网站公司晋江企业网站建设
  • 电商网站页面布局郑州技术支持seo
  • 做电脑系统最好的网站机关网站机制建设情况
  • 优化的含义是什么长沙网站seo优化排名