·目标:我们想要在跳转到一个页面之前,进行是否登陆的校验,只有已经登陆了,才能进入这个页面。
·实现步骤:
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("管理员已经登陆");
}
}
}