Java SpringBoot拦截器详解

网友投稿 434 2022-09-20


Java SpringBoot拦截器详解

目录1. 拦截器2. 拦截器使用2.1 准备工作2.2 Controller2.3 Interceptor2.4 Config2.5 测试2.5.1 正常登录2.5.2 非正常登录2.5.3 拦截器3. 总结

1. 拦截器

在 Spring Boot 可以可以在以下情况执行操作:

在将请求发送到控制器之前在将响应发送给客户端之前

2. 拦截器使用

下面实现一简单的登录验证功能。

2.1 准备工作

Step1:在前端页面添加thymeleaf支持;

Step2:主要的HTML内容如下:

注意:th:action="@{/SignUp}" 中的 URL 的 Controller 中定义。

Step3:Config 中添加视图控制器,实现 WebMvcConfigurer 接口中的 addViewControllers 方法;

@Override

public void addViewControllers(ViewControllerRegistry registry) {

registry.addViewController("/").setViewName("/SignUp");

registry.addViewController("/SignUp.html").setViewName("/SignUp");

registry.addViewController("/SuccessPage.html").setViewName("/SuccessPage");

}

2.2 Controller

实现登录的功能最主要的是Controller。在Controller中,为了简单方便,我们不走数据库,直接利用 equal 方法来比较参数。

@Controller

public class SignUpController {

@RequestMapping("/SignUp")

public String SignUp(@RequestParam("email") String email,

@RequestParam("password") String password,

Model model,

HttpSession session) {

if (email.equals("123@qq.com") && password.equals("123456")) {

session.setAttribute("email",email);

return "SuccessPage";

}else {

model.addAttribute("msg", "邮箱或密码错误");

return "SignUp";

}

}

}

在前端页面插入该 id 为 msg 的输出信息。

2.3 Interceptor

过滤器的实现如下:

public class SignUpInterceptor implements HandlerInterceptor {

@Override

public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

if(request.getSession().getAttribute("email") == null){

request.setAttribute("msg", "你没有权限进入,请登录");

request.getRequestDispatcher("SignUp.html").forward(request,response);

return false;

}else {

return true;

}

}

}

2.4 Config

Config 类实现了 WebMvcConfigurer 接口,添加拦截器需要实现其中 addInterceptors 方法。

addPathPatterns:指在和何处添加拦截器,/** 表示该路径下的所有文件及子目录的所有文件;

excludePathPatterns:表示需要排除拦截器的url

@Configuration

public class Boot_Config implements WebMvcConfigurer {

@Override

public void addInterceptors(InterceptorRegistry registry) {

registry.addInterceptor(new SignUpInterceptor()).addPathPatterns("/**").

excludePathPatterns("/","/SignUp","/SignUp.html");

}

}

2.5 测试

2.5.1 正常登录

2.5.2 非正常登录

2.5.3 拦截器

3. 总结

Spring Boot 是实现的拦截器与 Spring MVC 是一直的,只不过需要在 Config 中实现了 addInterceptors 方法。

文章中用到的页面放在了下面:

链接: https://pan.baidu.com/s/1jmc7Eq0uQCi2QTy2Q7zLdw提取码: ufjw

input标签实现了简单的验证功能,页面预览:

本篇文章就到这里了,希望能够给http://你带来帮助,也希望您能够多多关注我们的更懂欸组长


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:NAT——网络地址转换(nat网络地址转换详解)
下一篇:链路聚合(链路聚合的三种方式)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~