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

//已登陆,放行请求

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 {

}

}

  • 《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》无偿开源 威信搜索公众号【编程进阶路】 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名称空间



[](()文件上传功能

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

//MultipartFile—自动封装上传过来的文件

@PostMapping(“/upload”)

public String upload(@RequestParam(“name”)String name,

//单个文件上传

@RequestPart(“hs”) MultipartFile headImage,

//多文件上传–数组形式

@RequestPart(“ls”)MultipartFile[] photos) throws IOException {

//日志调试,{}是占位符,{}有几个,后面对应跟着的参数就需要有几个

log.info(“上传的信息: username={},headImage={},photos={}”,

name,headImage.getSize(),photos.length);

//下面展示将上传的文件,保存到电脑的对应磁盘路径

//上传的文件不为空,才保存到磁盘中

if(!headImage.isEmpty()){

//下面是获取上传文件的原始文件名

String originalFilename = headImage.getOriginalFilename();

headImage.transferTo(new File(“D:\resource\”+originalFilename));

}

//多文件上传,如果文件数组不为空,才进行保存操作

if(photos.length > 0){

for (MultipartFile photo : photos) {

if(!photo.isEmpty()){

String originalFilename = photo.getOriginalFilename();

photo.transferTo(new File(“D:\resource\”+originalFilename));

}

}

}

return “main”;

}

[](()表单部分的文件上传固定格式写法


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值