Spring實例Action的兩種方式:web
一、DelegatingActionProxy類整個Action由Spring實例
二、DelegatingRequestProcessor類extends RequestProcessor重寫processActionCreate方法,由Spring建立spring
web.xml
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>app
SSH整合第一式:缺點:麻煩一個方法對應一個<bean>如何實現整合的:
重寫了Action類的execute方法,使用Spring容器來實例bean,查找bean的名字是<action path="">的值
①struts-config.xml
<action ……
path="/doSave"
type="org.springframework.web.struts.DelegatingActionProxy">
</action>
②applicationContext.xml
<bean name="/doSave" class="com.yourcompany.struts.action.UserinfoAction">
<property name="manager" ref="userInfoManager"></property>
</bean>
註解:name="/doSave" 取得時<action path="/doSave" />ide
SSH整合第二式:第一式的延伸,使用MyDelegatingActionProxy類繼承DelegatingActionProxy和DispatchAction類
缺點:實現起來太繁瑣;優勢:一個Action類對應一個<bean>
①struts-config.xml
<action ……
type="com.yourcompany.struts.action.UserinfoAction">
</action>
②applicationContext.xml
<bean name="com.yourcompany.struts.action.UserinfoAction" class="com.yourcompany.struts.action.UserinfoAction">
<property name="manager" ref="userInfoManager"></property>
</bean>
③Action extends MyDelegatingActionProxy
註解:
一、若是不繼承DispatchAction類的話就會產生死循環調用execute方法的問題。
DelegatingActionProxy類的做用:改變Action類的建立方式,改爲由Spring容器建立的
DispatchAction類的做用:把execute方法分解成多個普通方法執行
二、屏蔽死循環問題必須在MyDelegatingActionProxy類重寫execute方法一下是此類的關鍵代碼:
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
Action delegateAction = getDelegateAction(mapping);
String parameter = getParameter(mapping, form, request, response);
String name = getMethodName(mapping, form, request, response, parameter);
return dispatchMethod(mapping, form, request, response, name,
delegateAction);
}spa
SSH整合第三式:使用DelegatingRequestProcessor類
缺點:一個方法一個<bean>
①struts-config.xml
<action ……
type="com.yourcompany.struts.action.UserinfoAction">
</action>
<controller>
<set-property property="processorClass" value="org.springframework.web.struts.DelegatingRequestProcessor"/>
</controller>
②applicationContext.xml
<bean name="/doSave" class="com.yourcompany.struts.action.UserinfoAction">
<property name="manager" ref="userInfoManager"></property>
</bean>
註解:name="/doSave" 取得時<action path="/doSave" />orm
SSH整合第四式:自定義MyDelegatingRequestProcessor類extends DelegatingRequestProcessor,重寫determineActionBeanName方法,return mapping.getType();
優勢:一個Action對應一個<bean>,[推薦,經常使用]
①struts-config.xml
<action ……
type="com.yourcompany.struts.action.UserinfoAction">
</action>
<controller>
<set-property property="processorClass" value="MyDelegatingRequestProcessor類路徑"/>
</controller>
②applicationContext.xml
<bean name="com.yourcompany.struts.action.UserinfoAction" class="com.yourcompany.struts.action.UserinfoAction">
<property name="manager" ref="userInfoManager"></property>
</bean>xml
SSH整合第五式:繼承ActionSupport、DispatchActionSupport、MappingDispatchActionSupport
①struts-config.xml
<action ……
type="com.yourcompany.struts.action.UserinfoAction">
</action>
②applicationContext.xml
<bean name="com.yourcompany.struts.action.UserinfoAction" class="com.yourcompany.struts.action.UserinfoAction" />
<bean id="userinfoManager" class="com.yourcompany.struts.action.UserinfoAction" />
註解:UserInfoAction extends MappingDispatchActionSupport實現onInit方法
manager=(IUserInfoManager) getWebApplicationContext().getBean("userInfoManager");
不須要set方法對象
問1:這段代碼在何時執行,起什麼做用?
<controller>
<set-property property="processorClass" value="org.springframework.web.struts.DelegatingActionProxy"/>
</controller>
答:在ActionServlet類的process方法中
RequestProcessor processor = getProcessorForModule(config);讀取返回一個RequestProcessor對象,若是沒有配置的話就會採起默認的,也就是Struts的核心類RequestProcessor繼承
問2:ContextLoaderPlugIn類的做用,如何使用?
答:在struts-config.xml中配置
<plug-in className="org.springframework.web.struts.ContextLoaderPlugIn">
<set-property property="contextConfigLication" value="/WEB-INF/classes/applicationContext.xml"/>
</plug-in>
至關於再web.xml中配置
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:applicationContext.xml</param-value>
</context-param>
道理是相同的。
通常是配置在web.xml中。get