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

外贸免费建设网站制作百度竞价排名医院事件

外贸免费建设网站制作,百度竞价排名医院事件,装修设计排行榜前十名,怎样做网站呢JWT JSON Web Token(JSON Web令牌) 是一个开放标准(rfc7519),它定义了一种紧凑的、自包含的方式,用于在各方之间以JSON对象安全地传输信息。此信息可以验证和信任,因为它是数字签名的。jwt可以使用秘密〈使用HNAC算法…

JWT

JSON Web Token(JSON Web令牌)

是一个开放标准(rfc7519),它定义了一种紧凑的、自包含的方式,用于在各方之间以JSON对象安全地传输信息。此信息可以验证和信任,因为它是数字签名的。jwt可以使用秘密〈使用HNAC算法)或使用RSA或ECDSA的公钥/私钥对进行签名。

通过JSON形式作为Web应用中的令牌,用于在各方之间安全地将信息作为JSON对象传输。在数据传输过程中还可以完成数据加密、签名等相关处理。

JWT登录流程

在这里插入图片描述
使用了JWT技术

流程:

1.前端通过表单的方式将用户的登录信息发送到后端

2.后端对登录的信息进行检验,合法的话生成JWT并与结果一起返回给前端

3.前端接收到返回结果进行响应并将JWT保存,前端可以将返回的结果保存在localStorage(浏览器本地缓存)或sessionStorage(session缓存)上,退出登录时前端删除保存的JWT即可

4.后续前端每次请求携带JWT进行,后端检查JWT 的合法性存在验证JWT的有效性。例如,检查签名是否正确﹔检查Token是否过期;检查Token的接收方是否是自己

5.验证通过后后端使用JWT中包含的用户信息进行其他逻辑操作,返回相应结果。

使用练习

1.引入依赖

<!--引入JWT-->
<dependency><groupId>com.auth0</groupId><artifactId>java-jwt</artifactId><version>3.10.0</version>
</dependency>

2.登录成功后,生成jwt令牌

  Map<String, Object> claims = new HashMap<>();claims.put(JwtClaimsConstant.EMP_ID, employee.getId());String token = JwtUtil.createJWT(jwtProperties.getAdminSecretKey(),jwtProperties.getAdminTtl(),claims);

3.在拦截器中配置token解析

//1、从请求头中获取令牌String token = request.getHeader(jwtProperties.getAdminTokenName());//2、校验令牌try {log.info("jwt校验:{}", 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);//3、通过,放行return true;} catch (Exception ex) {//4、不通过,响应401状态码response.setStatus(401);return false;}

4.封装JWT使用工具类(生成token和解密token)

  /*** 生成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;}
http://www.yidumall.com/news/22342.html

相关文章:

  • 网站建设时送的ppt方案电子商务营销策略
  • 可以用vs做网站建设吗seo免费推广
  • 如何修改单页网站seo优化检测
  • 福田做网站全国免费发布广告信息平台
  • 怎么查看网站是gbk营销型网站的特点
  • 东营网站建设哪家好免费域名注册官网
  • 网站网站建设轻松seo优化排名 快排
  • 建设模式有哪些北京网站seo优化推广
  • 奉贤广州网站建设sem是什么显微镜
  • php 建网站职业技能培训有哪些
  • 网站建设服务公司有哪些江门网站建设模板
  • 中国交通建设监理协会官方网站长尾关键词查询
  • 免费网站推广渠道北京百度总部电话
  • 戴尔cs24TY可以做网站吗自己怎么做百度推广
  • 免费视频网站制作电商运营培训
  • 网站制作公司兴田德润实力强seo什么意思
  • 佛山建网站定制要做网络推广
  • 网站会员整合广州最新疫情情况
  • 网站网站设计的公司项目推广计划书
  • 机械公司简介模板潍坊seo建站
  • 六安做网站公司关键词排名优化品牌
  • 黑马网站建设长沙百度开户
  • 越秀营销型网站站长工具外链查询
  • c 可以做网站吗网络营销策划ppt范例
  • 如何制作手机版网页福建优化seo
  • 温州网站建设制作爱站网挖掘词
  • 一流的五屏网站建设推广的软件有哪些
  • 淄博知名的做网站推广网络服务器是指什么
  • 东莞高端品牌网站建设手机注册网站
  • 基于jsp的网站建设论文上海百度搜索排名优化