I am trying to create an aspect that can be cut across my spring loaded struts actions. My struts actions work in spring, but my aop logging example does not.
<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<display-name>
Example1</display-name>
<!-- Spring integration -->
<listener>
<display-name>spring-applicationContext</display-name>
<listener-class>org.springframework.web.context.ContextLoade rListener</listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext*.xml</param-value>
</context-param>
<!-- Spring integration end-->
<servlet>
<servlet-name>action</servlet-name>
<servlet-class>
org.apache.struts.action.ActionServlet</servlet-class>
<init-param>
<param-name>config</param-name>
<param-value>/WEB-INF/struts-config.xml</param-value>
</init-param>
<init-param>
<param-name>debug</param-name>
<param-value>2</param-value>
</init-param>
<init-param>
<param-name>detail</param-name>
<param-value>2</param-value>
</init-param>
<init-param>
<param-name>validate</param-name>
<param-value>true</param-value>
</init-param>
<load-on-startup>2</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>action</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
</web-app>
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.1//EN" "http://jakarta.apache.org/struts/dtds/struts-config_1_1.dtd">
<struts-config>
<!-- Data Sources -->
<data-sources></data-sources>
<!-- Form Beans -->
<form-beans>
<form-bean name="form" type="example1.forms.Form"></form-bean>
<form-bean name="form2" type="example1.forms.Form2"></form-bean>
</form-beans>
<!-- Global Exceptions -->
<global-exceptions></global-exceptions>
<!-- Global Forwards -->
<global-forwards></global-forwards>
<!-- Action Mappings -->
<action-mappings>
<action path="/action1" type="org.springframework.web.struts.DelegatingAct ionProxy"
name="form" scope="request" input="/input.jsp">
<forward name="success" path="/output.jsp"></forward>
<forward name="failure" path="/input.jsp"></forward>
</action>
<action path="/action2" type="org.springframework.web.struts.DelegatingAct ionProxy"
scope="request" input="/output.jsp" name="form2">
<forward name="success" path="/final.jsp"></forward>
<forward name="failure" path="/output.jsp"></forward>
</action>
</action-mappings>
<!-- Message Resources -->
<message-resources
parameter="example1.resources.ApplicationResources " />
<plug-in className="org.apache.struts.validator.ValidatorPl ugIn">
<set-property property="pathnames"
value="/WEB-INF/validator-rules.xml,/WEB-INF/validation.xml" />
</plug-in>
<!-- Spring stuff -->
<plug-in
className="org.springframework.web.struts.ContextL oaderPlugIn">
<set-property property="csntextConfigLocation"
value="/WEB-INF/action-servlet.xml,/WEB-INF/applicationContext-web.xml" />
</plug-in>
<!-- End of Spring Stuff -->
</struts-config>
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schem...-beans-2.0.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schem...ng-aop-2.0.xsd ">
<aop:config proxy-target-class="true">
<aop:aspect ref="logging">
<aopointcut id="test1"
expression="execution(* example1.actions.*.*(..))" />
<aop:before pointcut-ref="test1" method="logBefore" />
<aop:after-returning pointcut-ref="test1" method="logAfter" />
</aop:aspect>
</aop:config>
<bean id="logging" class="example1.logging.LoggingExample" />
</beans>
package example1.logging;
public class LoggingExample {
public void logBefore () {
System.out.println("before an action");
}
public void logAfter () {
System.out.println("After an action");
}
}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
"http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
<bean name="/action1" class="example1.actions.Action1Action"></bean>
<bean name="/action2" class="example1.actions.Action2Action"></bean>
</beans>
Any assistance would be appreciated.
Mike


ointcut id="test1"
Reply With Quote
