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方法)
-
指定拦截规则,如果是拦截所有,静态资源也会被拦截
-
根据当前请求,找到HandlerExecutionChain【可以处理请求的handler以及handler的所有 拦截器】
-
先来顺序执行 所有拦截器的 preHandle方法
2.1如果当前拦截器prehandler返回为true。则执行下一个拦截器的preHandle
2.2 如果当前拦截器返回为false。直接倒序执行所有已经执行了的拦截器的 afterCompletion;
-
如果任何一个拦截器返回false。直接跳出不执行目标方法
-
所有拦截器都返回True。执行目标方法
-
倒序执行所有拦截器的postHandle方法。
-
前面的步骤有任何异常都会直接倒序触发已经执行了的拦截器的 afterCompletion
-
页面成功渲染完成以后,也会倒序触发 afterCompletion
thymeleaf可以通过抽取部分重复模板片段,减少重复工作量
==============================================================================================
Thymeleaf 模板布局 th:fragment、th:replace、th:insert、th:remove
任何一个页面,如果想要被thymeleaf模板引擎解析,都必须在对应页面引入模板引擎的th名称空间
=====================================================================
小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
结语
小编也是很有感触,如果一直都是在中小公司,没有接触过大型的互联网架构设计的话,只靠自己看书去提升可能一辈子都很难达到高级架构师的技术和认知高度。向厉害的人去学习是最有效减少时间摸索、精力浪费的方式。
我们选择的这个行业就一直要持续的学习,又很吃青春饭。
虽然大家可能经常见到说程序员年薪几十万,但这样的人毕竟不是大部份,要么是有名校光环,要么是在阿里华为这样的大企业。年龄一大,更有可能被裁。
送给每一位想学习Java小伙伴,用来提升自己。
本文到这里就结束了,喜欢的朋友可以帮忙点赞和评论一下,感谢支持!
是很有感触,如果一直都是在中小公司,没有接触过大型的互联网架构设计的话,只靠自己看书去提升可能一辈子都很难达到高级架构师的技术和认知高度。向厉害的人去学习是最有效减少时间摸索、精力浪费的方式。
我们选择的这个行业就一直要持续的学习,又很吃青春饭。
虽然大家可能经常见到说程序员年薪几十万,但这样的人毕竟不是大部份,要么是有名校光环,要么是在阿里华为这样的大企业。年龄一大,更有可能被裁。
送给每一位想学习Java小伙伴,用来提升自己。
[外链图片转存中…(img-FuWQYeV5-1710740630851)]
本文到这里就结束了,喜欢的朋友可以帮忙点赞和评论一下,感谢支持!