SpringMVC 如何使用注解完成登录拦截

作者:双鬼带单 时间:2023-11-18 02:20:11 

目录
  • 为了实现用户登录拦截你是否写过如下代码呢?

    • 1. 基于Filter

    • 2. 基于Struts

    • 3. 基于SpringMVC

  • 如何使用自定义注解完成自定义拦截呢?

    • 登录注解

    • SpringMVC * 设置

    • 最终 controller 写法

      • 1. 不需要登录权限的

      • 2. 整个 controller 内都需要登录权限

      • 3. controller 某个方法需要登录权限

为了实现用户登录拦截你是否写过如下代码呢?

1. 基于Filter


import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;

public class AuthenticationFilter implements Filter {
private FilterConfig filterConfig;
private String onErrorUrl;

public void init(FilterConfig filterConfig) throws ServletException {
// 从 filterConfig 中的得到错误页
this.filterConfig = filterConfig;
this.onErrorUrl = filterConfig.getInitParameter("onError");
if(this.onErrorUrl == null || "".equals(this.onErrorUrl))
this.onErrorUrl = "onError";
}

public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {

HttpServletRequest httpRequest = (HttpServletRequest)request;
session = httpRequest.getSession();
if(null == session.getAttribute("_LOGIN_USER_") && !"/login".equals(httpRequest.getServletPath())) {
httpRequest.getRequestDispatcher("/"+this.onErrorUrl).forward(request, response);
}else{
chain.doFilter(request, response);
}
}

public void destroy() {

}

}

2. 基于Struts


import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import org.apache.struts2.ServletActionContext;

import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;

@SuppressWarnings("serial")
public class LoginInterceptor extends AbstractInterceptor {

@Override
public String intercept(ActionInvocation invocation) throws Exception {
String currentUser="currentUser";
HttpServletRequest request=ServletActionContext.getRequest();
HttpServletResponse response=ServletActionContext.getResponse();
HttpSession session=request.getSession();
 if(request.getRequestURI().endsWith("login.action")){
  return invocation.invoke();
 } else {
if(session.getAttribute(currentUser)!=null){
return invocation.invoke();
}else{
response.sendRedirect(request.getContextPath()+"/login.jsp");
}
 }
return null;
}
}

3. 基于SpringMVC


import javax.servlet.RequestDispatcher;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import cn.edu.hdc.util.Constants;

/**
* @ClassName: LoginInterceptor
* @Description: 登录 *
* @author loweir hbloweir@163.com
* @date 2016年4月27日 上午8:06:11
*/
public class LoginInterceptor implements HandlerInterceptor {
/**
* 在目标方法前被调用,返回 true 继续
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object obj) throws Exception {
try {
String url = request.getRequestURI();
// 如果不是登录操作 判断 session
if (!url.endsWith("login")) {
if (request.getSession().getAttribute(Constants.CURRENT_USER) == null) {
 response.sendRedirect(request.getContextPath() + "/login.jsp");
return false;
}
}}
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}

@Override
public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {
}

@Override
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
throws Exception {

}
}

如何使用自定义注解完成自定义拦截呢?

登录注解


import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
* Created by loweir on 2017/5/14 17:19
* <p>
* author: 张瑀楠
* email: hbloweir@163.com
* 负责登录拦截
*/
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE,ElementType.METHOD})
public @interface WebLoginRequired {
String value() default ""; // 未登录时需要跳转的路径
}

SpringMVC * 设置


import com.ainsoft.globalshoperp.component.constant.WebLogin;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
* Created by loweir on 2017/5/14 17:14
* <p>
* author: 张瑀楠
* email: hbloweir@163.com
*/
public class LoginInterceptor implements HandlerInterceptor {

private static Log logger = LogFactory.getLog(LoginInterceptor.class);

public boolean preHandle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object handler) throws Exception {

if (logger.isDebugEnabled()) {
  logger.debug(" * 启动");
 }
 /*
 * 判断是否为 HandlerMethod.class
 * 如果不是说明当前请求并不是 SpringMVC 管理,
 * 如果不是再自行根据业务做响应操作,这里直接返回 true
 */
 if (HandlerMethod.class.isInstance(handler)) {
  HandlerMethod handlerMethod = (HandlerMethod) handler;

// 判断该 handler 是否有WebLoginRequired注解
  WebLoginRequired webLoginRequired = handlerMethod.getMethod().getDeclaredAnnotation(WebLoginRequired.class);

// 如果该 handler 没有WebLoginRequired注解,判断所属Controller 是否包含注解
  if (null == webLoginRequired) {
   webLoginRequired = handlerMethod.getBeanType().getAnnotation(WebLoginRequired.class);
  }

// 如果需要 WebLoginRequired 判断 session
  if (null != webLoginRequired) {
   if (httpServletRequest.getSession().getAttribute(WebLogin.CURRENTUSER) == null) {
    String executeURL = webLoginRequired.value();
    if (StringUtils.isBlank(executeURL)) {
     executeURL = WebLogin.LOGIN;
    }

httpServletResponse.sendRedirect(httpServletRequest.getContextPath() + executeURL);
    return false;
   }
  }
 }
 return true;
}

public void postHandle(javax.servlet.http.HttpServletRequest httpServletRequest, javax.servlet.http.HttpServletResponse httpServletResponse, Object o, ModelAndView modelAndView) throws Exception {
 if (logger.isDebugEnabled()) {
  logger.debug("postHandler");
 }
}

public void afterCompletion(javax.servlet.http.HttpServletRequest httpServletRequest, javax.servlet.http.HttpServletResponse httpServletResponse, Object o, Exception e) throws Exception {
 if (logger.isDebugEnabled()) {
  logger.debug("afterCompletion");
 }
}
}

最终 controller 写法

1. 不需要登录权限的

类和方法都不需要注解


@Controller
@RequestMapping("auth")
public class AuthController {

@RequestMapping("login")
public String login() {
 return "login";
}
}

2. 整个 controller 内都需要登录权限

在类上添加注解即可


@Controller
@WebLoginRequired
@RequestMapping("order")
public class OrderController {

@RequestMapping("index")
public String index() {
 return "index";
}
}

3. controller 某个方法需要登录权限

只在需要登录权限的方法上添加注解
在注解上可以指定需要重定向的链接
如果不指定则默认到 login


@Controller
@RequestMapping("order")
public class OrderController {

@RequestMapping("index")
public String index() {
 return "index";
}

// 需要登录
@WebLoginRequired
@RequestMapping("add")
public String index() {
 return "index";
}

// 需要登录,如果未登录跳到 error
@WebLoginRequired("error")
@RequestMapping("delete")
public String index() {
 return "index";
}
}

来源:https://www.cnblogs.com/zyndev/p/7613006.html

标签:SpringMVC,注解,登录拦截
0
投稿

猜你喜欢

  • WPF实现动画效果(七)之演示图板

    2021-08-18 20:31:53
  • C#字典Dictionary的用法说明(注重性能版)

    2023-08-05 19:33:02
  • java中List删除时需要的注意事项

    2023-11-11 01:28:00
  • Unity3D实现物体排成弧行

    2022-10-15 12:23:06
  • springboot依赖冲突问题及解决过程

    2023-03-13 11:49:53
  • Java乱码问题解决方法_动力节点Java学院整理

    2021-07-25 01:04:52
  • Android权限操作之uses-permission详解

    2023-07-20 17:07:02
  • Mybatis映射文件规则实例详解

    2022-04-22 03:08:14
  • java的main方法中调用spring的service方式

    2023-03-29 00:12:16
  • java程序设计语言的优势及特点

    2022-08-16 09:12:57
  • Java查看线程运行状态的方法详解

    2023-05-23 12:21:10
  • Java线程的生命周期和状态控制_动力节点Java学院整理

    2022-01-25 17:01:42
  • Android实现仿360桌面悬浮清理内存

    2021-08-25 11:21:05
  • spring cloud gateway网关路由分配代码实例解析

    2021-06-09 02:54:08
  • C# 正则判断一个数字的格式是否有逗号的代码

    2021-09-13 07:42:12
  • 浅谈C# 中的委托和事件

    2021-06-06 18:53:07
  • Spring Boot如何使用Spring Security进行安全控制

    2022-03-26 03:59:41
  • Android实现摇一摇功能

    2023-07-23 20:21:11
  • Android的Activity跳转动画各种效果整理

    2022-05-05 03:43:35
  • 分享WCF聊天程序--WCFChat实现代码

    2023-01-19 17:04:59
  • asp之家 软件编程 m.aspxhome.com