SpringBoot2----拦截器和文件上传功能

public class LoginHanlderIntercept implements HandlerInterceptor

{

@Override

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

Object user=request.getSession().getAttribute(“loginUser”);

if(user==null)

{

//未登陆,返回登陆页面

request.setAttribute(“msg”,“没有权限请先登陆”);

//转发到登录页

request.getRequestDispatcher(“/”).forward(request,response);

//重定向到登录页,但是这样是两次请求,那么登录页面就无法获取到request域中的值

//response.sendRedirect(“/”);

return false;

}

else

{

//已登陆,放行请求

return true;

}

}

@Override

public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {

}

@Override

public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {

}

}

  • 2.如果登录成功,那么往session中存放一个username作为登录凭证

@Controller

public class IndexController

{

//get方式的请求,来到登录页面

@GetMapping({“/”,“/login”})

public String ToLoginPage()

{

//到达登录页面

return “login”;

}

//post方式的请求来到主页面

@PostMapping(“/login”)

public String main(User user, HttpSession session, Model model)

{

//如果用户名和密码不为空,就放到session域中保存起来

if(!StringUtils.isEmpty(user.getUsername())&&!StringUtils.isEmpty(user.getPassword()))

{

//登录成功后,将登录用户的信息放入到session域中

session.setAttribute(“loginUser”,user);

//防止表单重复提交建议使用重定向

//登录成功重定向到main.html

return “redirect:main.html”;

}

else

{

model.addAttribute(“msg”,“账号密码错误”);

//回到主页

return “login”;

}

}

//去main页面

@GetMapping(“/main.html”)

public String mainPage()

{

return “main”;

}

}

  • 3.在springmvc扩展类中将自定义的拦截器进行注册

@Configuration

public class WebConfig implements WebMvcConfigurer

{

@Override

public void addInterceptors(InterceptorRegistry registry)

{

registry.addInterceptor(new LoginHanlderIntercept()).

//拦截任意多层路径下的所有请求,某些请求不进行拦截

addPathPatterns(“/**”).excludePathPatterns(“/”,“/login”)

//将静态资源文件夹的资源放行

.excludePathPatterns(“/css/“,”/fonts/”,“/images/“,”/js/”);

}

}


拦截器步骤总结


  • 编写一个拦截器实现HandlerInterceptor接口

  • 拦截器注册到容器中(实现WebMvcConfigurer的addInterceptor方法)

  • 指定拦截规则,如果是拦截所有,静态资源也会被拦截


拦截器原理


  1. 根据当前请求,找到HandlerExecutionChain【可以处理请求的handler以及handler的所有 拦截器】

  2. 先来顺序执行 所有拦截器的 preHandle方法

2.1如果当前拦截器prehandler返回为true。则执行下一个拦截器的preHandle

2.2 如果当前拦截器返回为false。直接倒序执行所有已经执行了的拦截器的 afterCompletion;

  1. 如果任何一个拦截器返回false。直接跳出不执行目标方法

  2. 所有拦截器都返回True。执行目标方法

  3. 倒序执行所有拦截器的postHandle方法。

  4. 前面的步骤有任何异常都会直接倒序触发已经执行了的拦截器的 afterCompletion

  5. 页面成功渲染完成以后,也会倒序触发 afterCompletion

在这里插入图片描述


thymeleaf可以通过抽取部分重复模板片段,减少重复工作量

==============================================================================================

Thymeleaf 模板布局 th:fragment、th:replace、th:insert、th:remove

任何一个页面,如果想要被thymeleaf模板引擎解析,都必须在对应页面引入模板引擎的th名称空间



文件上传功能

=====================================================================

小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
img

结语

小编也是很有感触,如果一直都是在中小公司,没有接触过大型的互联网架构设计的话,只靠自己看书去提升可能一辈子都很难达到高级架构师的技术和认知高度。向厉害的人去学习是最有效减少时间摸索、精力浪费的方式。

我们选择的这个行业就一直要持续的学习,又很吃青春饭。

虽然大家可能经常见到说程序员年薪几十万,但这样的人毕竟不是大部份,要么是有名校光环,要么是在阿里华为这样的大企业。年龄一大,更有可能被裁。

送给每一位想学习Java小伙伴,用来提升自己。

在这里插入图片描述

本文到这里就结束了,喜欢的朋友可以帮忙点赞和评论一下,感谢支持!

是很有感触,如果一直都是在中小公司,没有接触过大型的互联网架构设计的话,只靠自己看书去提升可能一辈子都很难达到高级架构师的技术和认知高度。向厉害的人去学习是最有效减少时间摸索、精力浪费的方式。

我们选择的这个行业就一直要持续的学习,又很吃青春饭。

虽然大家可能经常见到说程序员年薪几十万,但这样的人毕竟不是大部份,要么是有名校光环,要么是在阿里华为这样的大企业。年龄一大,更有可能被裁。

送给每一位想学习Java小伙伴,用来提升自己。

[外链图片转存中…(img-FuWQYeV5-1710740630851)]

本文到这里就结束了,喜欢的朋友可以帮忙点赞和评论一下,感谢支持!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 7
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Spring Boot 中,你可以通过使用拦截来统一限制上文件的类型和大小。拦截可以拦截所有的上请求,然后在上之前进行校验。 首先,你需要创建一个拦截类,并实现 HandlerInterceptor 接口。在拦截中,你可以重写 preHandle 方法来实现文件的校验。以下是一个简单的例子: ``` public class FileUploadInterceptor implements HandlerInterceptor { private static final long MAX_FILE_SIZE = 10 * 1024 * 1024; // 10MB private static final List<String> ALLOWED_CONTENT_TYPES = Arrays.asList("image/jpeg", "image/png"); @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { if (handler instanceof HandlerMethod) { HandlerMethod handlerMethod = (HandlerMethod) handler; // 检查方法是否有 @PostMapping 注解 PostMapping postMapping = handlerMethod.getMethodAnnotation(PostMapping.class); if (postMapping == null) { return true; } // 检查方法参数是否有 MultipartFile 类型 MethodParameter[] methodParameters = handlerMethod.getMethodParameters(); for (MethodParameter methodParameter : methodParameters) { if (methodParameter.getParameterType().equals(MultipartFile.class)) { MultipartFile file = (MultipartFile) request.getAttribute(methodParameter.getParameterName()); // 检查文件大小 if (file.getSize() > MAX_FILE_SIZE) { response.setStatus(HttpStatus.BAD_REQUEST.value()); response.getWriter().write("File size too large"); return false; } // 检查文件类型 String contentType = file.getContentType(); if (!ALLOWED_CONTENT_TYPES.contains(contentType)) { response.setStatus(HttpStatus.BAD_REQUEST.value()); response.getWriter().write("File type not allowed"); return false; } } } } return true; } } ``` 在上面的代码中,我们首先检查请求处理的方法是否有 @PostMapping 注解,并且是否有 MultipartFile 类型的参数。如果都符合条件,我们就可以从请求中获取到上文件,并进行校验。如果上文件不符合要求,我们就返回一个错误响应。否则,就放行请求,让请求继续被处理。 接下来,你需要在 Spring Boot 应用程序中注册这个拦截。你可以创建一个配置类,并实现 WebMvcConfigurer 接口。在这个配置类中,你可以重写 addInterceptors 方法来注册你的拦截。以下是一个简单的例子: ``` @Configuration public class WebMvcConfig implements WebMvcConfigurer { @Autowired private FileUploadInterceptor fileUploadInterceptor; @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(fileUploadInterceptor) .addPathPatterns("/upload"); } } ``` 在上面的代码中,我们首先创建了一个 WebMvcConfigurer 类,并注入了我们之前创建的 FileUploadInterceptor。然后,我们重写了 addInterceptors 方法,并将我们的拦截注册到了 /upload 路径下。这样,当用户上文件时,我们的拦截就会拦截请求,并对上文件进行校验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值