public class MVCInterceptor extends HandlerInterceptorAdapter { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler){ boolean flag = true; String requestURL = request.getRequestURI(); System.out.println(requestURL); UserInfo userInfo = (UserInfo)request.getSession() .getAttribute("user_info"); if (userInfo == null){//session不存在则跳转到重新登入 flag = false; try { response.sendRedirect("show_login"); } catch (IOException e){ e.printStackTrace(); } } //以下添加权限监测代码,如果不能直接执行此操作,可以建议过滤掉 return flag; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView){ } }
时间: 2023-06-18 11:04:27 浏览: 48
这是一个基于Spring MVC框架的拦截器(Interceptor),用于拦截请求并进行权限检查。在请求处理前,该拦截器会检查用户是否已经登录,如果没有登录则会重定向到登录页面。如果需要进行权限检查,可以在preHandle方法中添加相应的代码。
需要注意的是,该拦截器只是一个示例,具体的实现可能会有所不同。如果你想要使用该拦截器,需要将其配置到Spring MVC框架中。
相关问题
public class AdminInterceptor extends HandlerInterceptorAdapter{ /** * 检测登录状态 */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { String uri = request.getRequestURI(); if(uri.contains("css/") || uri.contains("js/") || uri.contains("img/") || uri.contains("login") || uri.contains("logout")) { return true; // 不拦截路径 } Object username = request.getSession().getAttribute("username"); if (Objects.nonNull(username) && !username.toString().trim().isEmpty()) { return true; // 登录验证通过 } response.sendRedirect("login.jsp"); return false; // 其他情况一律拦截 } }
这段代码是一个Spring MVC中的拦截器,用于拦截用户请求并检查用户是否已经登录。具体分析如下:
1. 继承HandlerInterceptorAdapter类
该类是Spring MVC中拦截器的基类,继承该类可以方便地实现拦截器。
2. 实现preHandle方法
preHandle是HandlerInterceptor接口中定义的一个方法,用于在Controller的方法执行前拦截请求。在preHandle方法中,可以编写自定义的拦截逻辑。
3. 判断请求路径是否需要拦截
首先,判断请求的URI是否包含"css/"、"js/"、"img/"、"login"或"logout",如果包含这些路径,则不拦截,直接放行。
4. 检查用户是否已经登录
如果请求的URI不包含上述路径,就需要检查用户是否已经登录。通过getSession().getAttribute("username")方法获取Session中的username属性,如果该属性不为null且不为空字符串,则表示用户已经登录,放行。
5. 重定向到登录页面
如果用户未登录,则通过response.sendRedirect("login.jsp")方法重定向到登录页面。并返回false,表示拦截请求。
综上所述,该拦截器用于对未登录的用户请求进行拦截,并重定向到登录页面,防止未授权访问系统。
java HandlerInterceptorAdapter中修改request中的参数
在 HandlerInterceptorAdapter 中,可以通过重写 preHandle 方法来修改 request 中的参数。具体步骤如下:
1. 获取 request 中的参数,可以通过 request.getParameter() 方法来获取。
2. 修改参数的值。
3. 将修改后的参数设置回 request 中,可以通过 request.setAttribute() 方法来设置。
以下是一个简单的示例代码:
```java
public class MyInterceptor extends HandlerInterceptorAdapter {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
String param = request.getParameter("param");
if (param != null) {
// 修改参数的值
String modifiedParam = param.toUpperCase();
// 将修改后的参数设置回 request 中
request.setAttribute("param", modifiedParam);
}
return true;
}
}
```
在上述代码中,我们将参数的值转换为大写,并将修改后的值设置回 request 中。这样,在后续的请求处理中,就可以使用修改后的参数值了。