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

天津河东网站建设公司建国电影院地址建国东路11号

天津河东网站建设公司,建国电影院地址建国东路11号,建筑工程总承包合同范本,宝塔一键部署wordpress最新版前面我们实现了给客户端下发token,虽然客户端拿到了token,但我们还没处理客户端下一次携带token请求时如何验证,我们想要实现拿得到token之后,只需要验证token,不需要用户再携带用户名和密码了。 1. 禁用 UsernamePass…

前面我们实现了给客户端下发token,虽然客户端拿到了token,但我们还没处理客户端下一次携带token请求时如何验证,我们想要实现拿得到token之后,只需要验证token,不需要用户再携带用户名和密码了。



1. 禁用 UsernamePasswordAuthenticationFilter



在这里插入图片描述

由上图可以看出,当用户访问了相关路径之后,Spring内部会自己创建一个UsernamePasswordAuthenticationFilter给我们,现在我们不想通过username和password进行认证了,我们想通过token进行验证,那就需要把内部创建的UsernamePasswordAuthenticationFilter给禁用了。

添加formLogin().disable到过滤链中:


在这里插入图片描述


为什么添加了这行代码就禁用了那个东西了呢?这是因为如果不禁用formLogin,它就会创建一个UsernamePasswordAuthenticationFilter


2. 创建自己的认证过滤器


禁用了UsernamePasswordAuthenticationFilter之后,我们就需要创建自己的过滤器,并把它添加到过滤链中,我们的验证过程就是在我们自己编写的过滤器中进行

在这里插入图片描述

@Slf4j
@Component
public class JWTAuthenticationFilter extends OncePerRequestFilter {@ResourceRedisTemplate redisTemplate;@Overrideprotected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {//如果是要登录,放行到登录页面if("/login2".equals(request.getRequestURI())){filterChain.doFilter(request, response);return;}//不是进行登录,说明前端会携带tokenString token = request.getHeader("Authorization");if(StrUtil.isEmpty(token))throw new RuntimeException("token 为空");//token类型:postman前端传来的token会在前面加一个类型和一个空格if(!StrUtil.startWith(token, "Bearer"))throw new RuntimeException("token 类型错误");//1. 验证tokentoken = token.substring(7);JWTSigner jwtSigner = JWTSignerUtil.hs512("testttttt".getBytes(StandardCharsets.UTF_8));if (!JWTUtil.verify(token, jwtSigner)) {throw new RuntimeException("token 无效");}//2. 从token中取出用户名String username = (String) JWTUtil.parseToken(token).getPayload().getClaim("username");//3. 根据用户名从redis中取出password(登录时可以将UserDetails存储到redis)String password = (String) redisTemplate.opsForHash().get("user-details", username);if(password == null) throw new RemoteException("token 过期");log.info("--------> get password= {}", password);//4. new一个UserDetails,这个UserDetails会被存储到SecurityContextHolder中MyUserDetails userDetails = new MyUserDetails(new MyUser(1, username, password));//5. 将UserDetails存储到SecurityContextHolder中SecurityContextHolder.getContext().setAuthentication(UsernamePasswordAuthenticationToken.authenticated(userDetails, null, null));filterChain.doFilter(request, response);}
}

注意,代码中的第5步决定是否放行请求,只有将UserDetails存储到SecurityContextHolder中,过滤器才会放行。


将编写好的过滤器添加到过滤器链中:




在这里插入图片描述

.addFilterAt(jwtAuthenticationFilter, UsernamePasswordAuthenticationFilter.class);

3. 测试

可以看到,用户首次登录之后,后端成功返回一个token



在这里插入图片描述

接下来携带token请求另一个页面。


在这里插入图片描述


成功返回结果:

在这里插入图片描述


EX++++++++++++++

经过测验发现,放行和不放行完全取决于这行代码:


在这里插入图片描述

SecurityContextHolder.getContext().setAuthentication(UsernamePasswordAuthenticationToken.authenticated(userDetails, null, null));

我甚至可以直接写成

SecurityContextHolder.getContext().setAuthentication(new UsernamePasswordAuthenticationToken(userDetails, null, null));

因为UsernamePasswordAuthenticationToken.authenticated(userDetails, null, null)这个函数在底层就是会直接new一个UsernamePasswordAuthenticationToken

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

相关文章:

  • 网站网络资源建立crm客户管理
  • 网站建设在线如何做网站来做淘宝客
  • 免费logo设计在线生成器钙网wordpress 4.9 优化
  • 乐清建设路小学校园网站淘客网站佣金建设
  • 网站主页不收录餐饮酒店网站建设
  • 米拓cms 网站模板在哪icp备案单位网站
  • 站长工具域名云梦建站
  • 凯里网站建设公司网页设计规范2018
  • 网站建设 内容缺乏wordpress 导出表单
  • 青浦区网站建设费用合肥论坛网
  • 匠人精神网站建设建设一个网站需要哪些员工
  • 兰州市建设厅官方网站国际1688网站
  • 爱站网关键词挖掘创建网站大约多少钱
  • 网站模板使用教程郑州市工程建设信息网
  • php建站模板wordpress主题开发出
  • 自己做网站 有名6哪个网站建设好
  • 建设网站的内容规划网站开发的职业技术方面
  • 赣州做网站j怎么把网站放到空间吗
  • 中山森斯网站建设公司百度小说搜索风云榜排行榜
  • 网站建设公司ttmwlwordpress绿色框
  • 专业营销软件网站建设为什么做游戏网站被封
  • 姑苏网站建设淘宝客做自己的网站
  • 自己电脑建设网站网站建设分工方案
  • 网站建网站建设网站站网站毕设做桌面软件 网站
  • 闸北微信网站建设外面网站怎么做
  • 19寸 网站做多大google 官网入口
  • wordpress 移动 建站蛋糕网站设计
  • 宝坻建设路小学网站做甜品的网站
  • 网站设计入门商城网站建设制作
  • 征婚网站上教人做恒指期货大型网站的标准