基于注解的aop,实现拦截controller进行登陆校验

·目标:我们想要在跳转到一个页面之前,进行是否登陆的校验,只有已经登陆了,才能进入这个页面。

·实现步骤:

1、导入aop相关jar包

                <!--AOP-->
		<dependency>
		<groupId>org.springframework</groupId>
		<artifactId>spring-aop</artifactId>
		<version>${spring.version}</version>
		</dependency>
		<dependency>
		<groupId>org.springframework</groupId>
		<artifactId>spring-aspects</artifactId>
		<version>${spring.version}</version>
		</dependency>
		 
		<!--Aspectj-->
		<dependency>
		<groupId>aopalliance</groupId>
		<artifactId>aopalliance</artifactId>
		<version>1.0</version>
		</dependency>
		<dependency>
		<groupId>org.aspectj</groupId>
		<artifactId>aspectjweaver</artifactId>
		<version>1.8.10</version>
		</dependency>
		 <!-- cglib -->
		<dependency>
		<groupId>cglib</groupId>
		<artifactId>cglib</artifactId>
		<version>2.2</version>
		</dependency>

2、配置aop和扫描aop

   *注意:1、aop的配置必须加上proxy-target-class="true",作用是让controller被cglib代理,从而不实现接口也可以被aop拦截。

               2、如果切点是想拦截controller,aop的配置和扫描必须放在扫描controller之前进行,否则不生效。

              3、配置文件的加载顺序:我在web.xml中配置了加载springmvc配置文件是一启动就加载(<load-on-startup>1</load-on-startup>),所以顺序是mvc→spring

在mvc的配置文件里的扫描controller之前加上。

<!--aspectj自动代理,将proxy-target-class=true,不管目标是否有接口,都会使用cglib进行代理-->
	<!--通知spring使用cglib而不是jdk的来生成代理方法 AOP可以拦截到Controller-> -->
	<aop:aspectj-autoproxy proxy-target-class="true" />
	<!-- 扫描aop -->
	<context:component-scan base-package="cn.edu.sjzc.aop"></context:component-scan>
	<context:component-scan base-package="cn.edu.sjzc.controller" />
	<!-- 扫描controller ,controller交给springmvc控制,所以该标签必须写在springmvc的配置文件中,否则会出问题-->
	<context:component-scan base-package="cn.edu.sjzc.controller" />

3、编写aop的切面类

@Aspect //声明切面类
@Component //注册bean
//aop验证管理员是否登陆
public class MyAspect {
	@Pointcut("execution(public * cn.edu.sjzc.controller.OrderController.orderlist())"+
				"||execution(public * cn.edu.sjzc.controller.GoodsController.to*(..))"+
				"||execution(public * cn.edu.sjzc.controller.GoodsTypeController.to*(..))"+
				"||execution(public * cn.edu.sjzc.controller.DiscountNumController.to*(..))")//定义了多个切点
	 public void pointcut(){
		//System.out.println("这是切点。。。。。。");
	}
	
	@Before("pointcut()")
    public void before() throws IOException{
		HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
		HttpServletResponse response = ((ServletRequestAttributes)RequestContextHolder.getRequestAttributes()).getResponse();
		HttpSession session = request.getSession();
         System.out.println(session.getAttribute("aid"));
        if(session.getAttribute("aid")==null||session.getAttribute("aid")==""){
            System.out.println("管理员没有登陆");
            response.sendRedirect(request.getContextPath() + "/adminLogin.html");
        }
        else {
			System.out.println("管理员已经登陆");
		}
         
    }
	
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值