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

昌平网站开发公司那么多网站都是谁做的

昌平网站开发公司,那么多网站都是谁做的,安徽网新科技怎么建设网站,php自己写框架做网站6使用步骤&#xff1a; 1.导入jwt相关依赖 2.创建jwt工具类方便使用 3.通过工具类提供的方法进行生成jwt 4.通过工具类解析jwt令牌获取封装的数据 5.设定拦截器&#xff0c;每次执行请求的时候都需要验证token 6.注册拦截器 1.jwt依赖 <dependency><groupId>io.json…

使用步骤:

1.导入jwt相关依赖

2.创建jwt工具类方便使用

3.通过工具类提供的方法进行生成jwt

4.通过工具类解析jwt令牌获取封装的数据

5.设定拦截器,每次执行请求的时候都需要验证token

6.注册拦截器


1.jwt依赖

<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-api</artifactId><version>0.11.2</version>
</dependency>
<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-impl</artifactId><version>0.11.2</version>
</dependency>
<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt-jackson</artifactId> <!-- 或者 jjwt-gson 如果你使用Gson --><version>0.11.2</version>
</dependency>

相关作用

1. jjwt-api

作用:提供了JWT的核心API接口和类,定义了JWT的生成和解析的基本操作。

2. jjwt-impl

作用:提供了 jjwt-api 中定义的接口的具体实现,包括JWT的生成和解析的实际逻辑。

3. jjwt-jackson 或 jjwt-gson

作用:提供了序列化和反序列化JWT的工具,分别支持Jackson和Gson库。选择其中一个即可,具体取决于你的项目中使用的JSON处理库。

2.jwt工具类

package com.sky.utils;import io.jsonwebtoken.Claims;
import io.jsonwebtoken.JwtBuilder;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import java.nio.charset.StandardCharsets;
import java.util.Date;
import java.util.Map;public class JwtUtil {/*** 生成jwt* 使用Hs256算法, 私匙使用固定秘钥** @param secretKey jwt秘钥* @param ttlMillis jwt过期时间(毫秒)* @param claims    设置的信息* @return*/public static String createJWT(String secretKey, long ttlMillis, Map<String, Object> claims) {// 指定签名的时候使用的签名算法,也就是header那部分SignatureAlgorithm signatureAlgorithm = SignatureAlgorithm.HS256;// 生成JWT的时间long expMillis = System.currentTimeMillis() + ttlMillis;Date exp = new Date(expMillis);// 设置jwt的bodyJwtBuilder builder = Jwts.builder()// 如果有私有声明,一定要先设置这个自己创建的私有的声明,这个是给builder的claim赋值,一旦写在标准的声明赋值之后,就是覆盖了那些标准的声明的.setClaims(claims)// 设置签名使用的签名算法和签名使用的秘钥.signWith(signatureAlgorithm, secretKey.getBytes(StandardCharsets.UTF_8))// 设置过期时间.setExpiration(exp);return builder.compact();}/*** Token解密** @param secretKey jwt秘钥 此秘钥一定要保留好在服务端, 不能暴露出去, 否则sign就可以被伪造, 如果对接多个客户端建议改造成多个* @param token     加密后的token* @return*/public static Claims parseJWT(String secretKey, String token) {// 得到DefaultJwtParserClaims claims = Jwts.parser()// 设置签名的秘钥.setSigningKey(secretKey.getBytes(StandardCharsets.UTF_8))// 设置需要解析的jwt.parseClaimsJws(token).getBody();return claims;}}

3.设定拦截器

package com.sky.interceptor;import com.sky.constant.JwtClaimsConstant;
import com.sky.context.BaseContext;
import com.sky.properties.JwtProperties;
import com.sky.utils.JwtUtil;
import io.jsonwebtoken.Claims;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerInterceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;/*** jwt令牌校验的拦截器*/
@Component
@Slf4j
public class JwtTokenAdminInterceptor implements HandlerInterceptor {// 注入jwt配置对象@Autowiredprivate JwtProperties jwtProperties;/*** 校验jwt** @param request* @param response* @param handler* @return* @throws Exception*/public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {//判断当前拦截到的是Controller的方法还是其他资源if (!(handler instanceof HandlerMethod)) {//当前拦截到的不是动态方法,直接放行return true;}//1、从请求头中获取令牌 getAdminTokenName是配置文件中的属性,在JwtProperties中定义String token = request.getHeader(jwtProperties.getAdminTokenName());//2、校验令牌try {log.info("token校验:{}", token);Claims claims = JwtUtil.parseJWT(jwtProperties.getAdminSecretKey(), token);Long empId = Long.valueOf(claims.get(JwtClaimsConstant.EMP_ID).toString());log.info("当前员工id:{}", empId);BaseContext.setCurrentId(empId);System.out.println(BaseContext.getCurrentId());//3、通过,放行return true;} catch (Exception ex) {//4、不通过,响应401状态码response.setStatus(401);return false;}}
}

4.注册拦截器

package com.sky.config;import com.sky.interceptor.JwtTokenAdminInterceptor;
import lombok.extern.slf4j.Slf4j;
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.WebMvcConfigurationSupport;/*** 配置类,注册web层相关组件*/
@Configuration
@Slf4j
public class WebMvcConfiguration extends WebMvcConfigurationSupport {@Autowiredprivate JwtTokenAdminInterceptor jwtTokenAdminInterceptor;/*** 注册自定义拦截器** @param registry*/protected void addInterceptors(InterceptorRegistry registry) {log.info("开始注册自定义拦截器...");registry.addInterceptor(jwtTokenAdminInterceptor)// 除了登录接口,其他接口都拦截.addPathPatterns("/admin/**")// 登录接口放行.excludePathPatterns("/admin/employee/login");}
}

作用:

这段Java代码定义了一个名为 JwtUtil 的工具类,用于生成和解析JWT(JSON Web Token)

createJWT 方法:

生成JWT令牌。

使用HS256算法进行签名。

接受三个参数:secretKey(秘钥)、ttlMillis(过期时间,单位为毫秒)

claims(自定义声明)。

返回生成的JWT字符串。


parseJWT 方法:

解析JWT令牌。

验证签名是否正确。

接受两个参数:secretKey(秘钥)、token(加密后的令牌)。

返回解析后的声明信息。

http://www.yayakq.cn/news/191603/

相关文章:

  • 网站群系统建设标准网络营销八大目标是什么
  • 做个网站要多久邢台推广网站建设电话
  • 重庆奉节网站建设公司网站建设一般收费
  • 湖南建设网站获客系统怎样把网站做的更吸引
  • 旅游药都网站建设方案自己架设服务器做网站
  • 航天基地规划建设局网站做网络维护的公司有哪些
  • 昆明专业的网站制作建设网站建设与管理专业人才调研
  • 互联网+体育消费湖南seo推广多少钱
  • 个人网站该怎么打广告专业做公司logo的网站
  • 国内网站设计欣赏办公室装修设计招商
  • 自己做网站要多久网站即将上线 模板
  • 如何用个人电脑做网站电子商务专业网站建设
  • 男男做爰视频网站无锡网站营销公司
  • 论坛做视频网站国内广告公司排行
  • 有没有电脑做兼职的网站学做包子馒头的网站
  • 自己做轴承网站房子网站有哪些
  • 翠屏区网站建设企业网站建设需要什么资料
  • 做网站副业wordpress设置先登录再进入
  • 腾讯云自助建站长沙企业做网站哪家好
  • 正规的装饰行业网站建设公司wordpress主题ftp失败
  • 广州车陂网站建设中心企业网站设计seo
  • 个人做电子商务网站再网站里做商家店铺
  • 合肥电脑网站建站自己如何制作网页
  • 怎么做体育直播网站wordpress写入html
  • 北京网站建设成都公司常德微网站开发
  • 网站dns如何修改不了网天蝎网站建设公司
  • 沧浪苏州网站建设网站专项审批查询
  • 成都建立网站自己做的娱乐平台网站
  • 建设网站需要什么手续室内设计公司排行榜
  • 建设银行暑期招聘网站聚名网页版