使用Spring配置文件实现AOP

首先,除spring的基本jar文件外需要一个包:

<!-- springAOP配置 -->
 <aop:aspectj-autoproxy></aop:aspectj-autoproxy>
 <bean id="interceptor" class="com.user.aop.Interceptor" />
 <aop:config>
  <aop:aspect id="asp" ref="interceptor">
   <aop:pointcut id="mycut"
    expression="execution(* com.user.controller..*.*(..))" />
   <aop:before pointcut-ref="mycut" method="doAccessCheck"/>
   <aop:after-returning pointcut-ref="mycut"
    method="doAfterReturning" />
   <aop:after-throwing pointcut-ref="mycut" method="doAfterThrowing" />
   <aop:after pointcut-ref="mycut" method="doAfter" />
   <aop:around pointcut-ref="mycut" method="doBasicProfiling"/>
  </aop:aspect>
 </aop:config>

对应的java文件如下:

package com.user.aop;

import java.io.IOException;

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

import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.Aspect; import org.springframework.beans.factory.annotation.Autowired;

import com.user.util.GetContent;

@Aspect public class Interceptor{  @Autowired  GetContent getContent;

 public void setResponseInScopeFilter(GetContent getContent) {   this.getContent = getContent;  }    @SuppressWarnings("unused")  public void doAccessCheck() throws IOException {   System.out.println("前置通知");   HttpServletRequest request = getContent.getRequest();   HttpServletResponse respine = getContent.getRespone();  }

 public void doAfterReturning() {   System.out.println("后置通知");  }

 public void doAfter() {   System.out.println("最终通知");  }

 public void doAfterThrowing() {   System.out.println("异常通知");  }

 public Object doBasicProfiling(ProceedingJoinPoint pjp) throws Throwable {   System.out.println("环绕通知");   Object result = pjp.proceed();//此方法将会创建配置文件中所指定的需要代理的类   return result;  }   }

解决代理类中无法使用servlet的内置对象的问题:当然,这里是需要spring-web这个包的,其实我认为这个包也就是封装了servlet,你们可以把servlet的包和这个包解压出来对比下看是否有类似之处

1、首先需要配置web.xml捕获页面的request请求
配置文件如下:

<filter>
        <filter-name>responseInScopeFilter</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
        <init-param>
            <param-name>targetBeanName</param-name>
            <param-value>getContent</param-value>
        </init-param>
    </filter>
  <filter-mapping>
        <filter-name>responseInScopeFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

2、上文中getContent是将捕获到的页面请求交给getContent这个bean,也就是交给你所指定的类,你懂的 - -!所以,还需要在spring的配置文件中定义这个bean:

	<!-- 创建HttpServletRequest和HttpServletRespone对象 -->
	<bean id="getContent" class="com.user.util.GetContent"></bean>

3、下面是bean所指定的类的java文件:注意:这个类能够得到servlet的请求是因为实现了Filter这个接口

package com.user.util;

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.HttpServletResponse;

public class GetContent implements Filter{
	//ThreadLocal可以对HttpServletRequest进行线程管理,使每次请求互不干扰
	private static ThreadLocal<HttpServletRequest> requestLocal= new ThreadLocal<HttpServletRequest>();  
    private static ThreadLocal<HttpServletResponse> responseLocal= new ThreadLocal<HttpServletResponse>();
	public void destroy() {
		System.out.println("销毁servlet");
	}
	
	public void doFilter(ServletRequest arg0, ServletResponse arg1,
			FilterChain arg2) throws IOException, ServletException {
		requestLocal.set((HttpServletRequest)arg0);
		responseLocal.set((HttpServletResponse)arg1);
		arg2.doFilter(arg0, arg1);  

	}
	
	public HttpServletRequest getRequest(){
		return requestLocal.get();
	}
	public HttpServletResponse getRespone(){
		return responseLocal.get();
	}
	
	public void init(FilterConfig arg0) throws ServletException {
		System.out.println("初始化servlet");
		
	}
}

4、这样我们就能够在GetContent类中得到servlet的请求HttpServletRequest或者HttpServletResponse等,再回头看看代理类中是不是使用了注解方式将getContent这个bean注入到Interceptor这个类中?接下来代理类就能够得到servlet的请求了,


 


 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
图像识别技术在病虫害检测中的应用是一个快速发展的领域,它结合了计算机视觉和机器学习算法来自动识别和分类植物上的病虫害。以下是这一技术的一些关键步骤和组成部分: 1. **数据收集**:首先需要收集大量的植物图像数据,这些数据包括健康植物的图像以及受不同病虫害影响的植物图像。 2. **图像预处理**:对收集到的图像进行处理,以提高后续分析的准确性。这可能包括调整亮度、对比度、去噪、裁剪、缩放等。 3. **特征提取**:从图像中提取有助于识别病虫害的特征。这些特征可能包括颜色、纹理、形状、边缘等。 4. **模型训练**:使用机器学习算法(如支持向量机、随机森林、卷积神经网络等)来训练模型。训练过程中,算法会学习如何根据提取的特征来识别不同的病虫害。 5. **模型验证和测试**:在独立的测试集上验证模型的性能,以确保其准确性和泛化能力。 6. **部署和应用**:将训练好的模型部署到实际的病虫害检测系统中,可以是移动应用、网页服务或集成到智能农业设备中。 7. **实时监测**:在实际应用中,系统可以实时接收植物图像,并快速给出病虫害的检测结果。 8. **持续学习**:随着时间的推移,系统可以不断学习新的病虫害样本,以提高其识别能力。 9. **用户界面**:为了方便用户使用,通常会有一个用户友好的界面,显示检测结果,并提供进一步的指导或建议。 这项技术的优势在于它可以快速、准确地识别出病虫害,甚至在早期阶段就能发现问题,从而及时采取措施。此外,它还可以减少对化学农药的依赖,支持可持续农业发展。随着技术的不断进步,图像识别在病虫害检测中的应用将越来越广泛。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值