[Java Spring MVC] Introduction to interceptors
Interceptor jump in before controller. So request may not reach controller if Pre-process is not ok.
Demo:
package com.test.hplus.interceptors; import org.springframework.web.servlet.ModelAndView; import org.springframework.web.servlet.handler.HandlerInterceptorAdapter; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.util.Date; public class LoggingInterceptor extends HandlerInterceptorAdapter { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { //get all cookies //log session id: //log the request path String sessionId = null; if(null!=request.getCookies()){ for(Cookie cookie: request.getCookies()){ if("JSESSIONID".equals(cookie.getName())){ sessionId = cookie.getValue(); } } } System.out.println("Incoming request data log: session: "+sessionId+ " at "+ new Date()+" for "+request.getRequestURI()); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { System.out.println("in post handle"); } }
Add inteceptor to conifg:
@Configuration @ComponentScan(basePackages = "com.test.hplus") public class ApplicationConfig extends WebMvcConfigurationSupport { ... @Override protected void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(new LoggingInterceptor()).addPathPatterns("/*"); } }
For each requests, login interceptor will jump in.
Forwarding request from login controller to profile controller:
@PostMapping("/login") public String login(@ModelAttribute("login")Login login){ User user = userRepository.searchByName(login.getUsername()); if(user==null){ throw new ApplicationException("User not found"); } return "forward:/userprofile"; }
@Controller public class UserProfileController { @PostMapping("/userprofile") public String getUserProfile(@SessionAttribute("login")Login login, Model model){ System.out.println("in user profile controller"); System.out.println("username from session: "+login.getUsername()); //call to userrepository to get all the user information model.addAttribute("username", login.getUsername()); return "profile"; } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2020-01-15 [NestJS] Fallback Exception Filter
2020-01-15 [Git] Add a File to a Previous Commit with Interactive Rebase
2020-01-15 [React] Implement useState with useReducer
2019-01-15 [TypeScript] Use the JavaScript “in” operator for automatic type inference in TypeScript
2019-01-15 [Javascript] Use a Pure RNG with the State ADT to Select an Element from State
2018-01-15 [Mobx] Using mobx to isolate a React component state
2018-01-15 [Javascript] Simplify Creating Immutable Data Trees With Immer