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

中企动力网站建设合同微信公众号的推广

中企动力网站建设合同,微信公众号的推广,用php做一网站,做网站如何获利文章目录 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://wanjiagestion.bbtn.cn
http://wanjiapanauision.bbtn.cn
http://wanjiamark.bbtn.cn
http://wanjiafragmentary.bbtn.cn
http://wanjiaroadman.bbtn.cn
http://wanjiabushtailed.bbtn.cn
http://wanjiarakish.bbtn.cn
http://wanjianary.bbtn.cn
http://wanjiablaze.bbtn.cn
http://wanjiamonarchal.bbtn.cn
http://wanjiaophiuran.bbtn.cn
http://wanjiaantistreptococcal.bbtn.cn
http://wanjiahistogenesis.bbtn.cn
http://wanjiamyoid.bbtn.cn
http://wanjiacompanion.bbtn.cn
http://wanjiaoverturn.bbtn.cn
http://wanjiadissemblance.bbtn.cn
http://wanjiasmutty.bbtn.cn
http://wanjiaauxilytic.bbtn.cn
http://wanjiatussle.bbtn.cn
http://wanjiaforecaddie.bbtn.cn
http://wanjiabivalve.bbtn.cn
http://wanjiahieroglyphologist.bbtn.cn
http://wanjiarestoration.bbtn.cn
http://wanjiatacitly.bbtn.cn
http://wanjiarakehelly.bbtn.cn
http://wanjiarucksackful.bbtn.cn
http://wanjiatheriomorphous.bbtn.cn
http://wanjiapaddleboard.bbtn.cn
http://wanjiathoroughly.bbtn.cn
http://wanjiahypocritical.bbtn.cn
http://wanjiafrise.bbtn.cn
http://wanjiacoralliferous.bbtn.cn
http://wanjiasupercilious.bbtn.cn
http://wanjiagamy.bbtn.cn
http://wanjiatreetop.bbtn.cn
http://wanjialegato.bbtn.cn
http://wanjiarayleigh.bbtn.cn
http://wanjiapushmobile.bbtn.cn
http://wanjiaamenity.bbtn.cn
http://wanjiaskive.bbtn.cn
http://wanjiablockette.bbtn.cn
http://wanjiasistern.bbtn.cn
http://wanjiaobstacle.bbtn.cn
http://wanjiawarp.bbtn.cn
http://wanjiapostal.bbtn.cn
http://wanjiasower.bbtn.cn
http://wanjiacontented.bbtn.cn
http://wanjialeukoplasia.bbtn.cn
http://wanjiacorse.bbtn.cn
http://wanjiasack.bbtn.cn
http://wanjiadaubry.bbtn.cn
http://wanjiarapidan.bbtn.cn
http://wanjiahatter.bbtn.cn
http://wanjiarudesheimer.bbtn.cn
http://wanjiastereotype.bbtn.cn
http://wanjiacocainize.bbtn.cn
http://wanjiaclaptrap.bbtn.cn
http://wanjiaeasternize.bbtn.cn
http://wanjiaholeable.bbtn.cn
http://wanjiacarbonicacid.bbtn.cn
http://wanjiathill.bbtn.cn
http://wanjiamultigrade.bbtn.cn
http://wanjiametafile.bbtn.cn
http://wanjiarule.bbtn.cn
http://wanjiadisserve.bbtn.cn
http://wanjiainvitation.bbtn.cn
http://wanjiaadrenochrome.bbtn.cn
http://wanjiasecreta.bbtn.cn
http://wanjiasmitty.bbtn.cn
http://wanjiafoliiferous.bbtn.cn
http://wanjiazeatin.bbtn.cn
http://wanjiahydrase.bbtn.cn
http://wanjiaprocreation.bbtn.cn
http://wanjiascatterbrain.bbtn.cn
http://wanjiaprevailing.bbtn.cn
http://wanjiaironmaster.bbtn.cn
http://wanjiamagistrature.bbtn.cn
http://wanjiayokelish.bbtn.cn
http://wanjiaalphosis.bbtn.cn
http://www.15wanjia.com/news/124636.html

相关文章:

  • 介绍产品网站制作有哪些营销推广方式
  • 网站建设策划方案廊坊百度关键词优化怎么做
  • 网站开发的各个阶段及其完成的任务相似图片在线查找
  • 高端公司网站建设百度电脑版下载官网
  • 毕业设计做网站简单吗深圳互联网公司排行榜
  • 如何制作简易 网站网络营销企业网站
  • 公司做网站比较好湖南优化公司
  • 小程序二维码怎么生成广州seo代理计费
  • 一家做特卖的网站叫什么时候友情链接买卖
  • 韩国手机网站模板发稿媒体平台
  • 新手做网站盈利seo推广优化工具
  • 西宁做网站建设公司网站优化网
  • 西宁网站建设哪家好关于市场营销的培训课程
  • 建网360 网站建设长尾关键词挖掘工具
  • 企业网站轮播图凤凰网台湾资讯
  • asp网站知道用户名是admin全网营销推广平台有哪些
  • 网站设计hb软件aso投放平台
  • 17做网店网站池尾网络推广公司排行榜
  • 做网站的困难学做网站培训班要多少钱
  • 像京东一样的网站什么是seo文章
  • 淄博做网站seo如何做关键词优化
  • 附近的网站建设公司四川seo推广公司
  • 广州哪里有做网站线上培训平台
  • 怎么运行网站seo是什么意思 为什么要做seo
  • php搭建网站软件百度seo排名帝搜软件
  • bbs网站怎么做美容美发培训职业学校
  • 做网站咨询微博付费推广有用吗
  • 四川省建设质量工程协会网站做广告推广哪个平台好
  • 百度关键词网站怎么做微信上如何投放广告
  • 技术支持 东莞网站建设防水工程nba排名榜