任何MVC框架都需要与Web应用整合,这就不得不借助于web.xml文件,只有配置在web.xml文件中Servlet才会被应用加载。
通常,所有的MVC框架都需要Web应用加载一个核心控制器,对于Struts2框架而言,需要加载FilterDispatcher,只要Web应用负责加载FilterDispatcher,FilterDispatcher将会加载Struts2框架。
因为Struts2将核心控制器设计成Filter,而不是一个普通Servlet。故为了让Web应用加载FilterDispatcher,只需要在web.xml文件中配置FilterDispatcher即可。
标准配置文件如下:
Java代码 收藏代码
01. <?xml version="1.0" encoding="UTF-8"?>
02. <web-app id="WebApp_9" 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">
03.
04. <display-name>Struts Blank</display-name>
05.
06. <filter>
07. <!-- 配置Struts2核心Filter的名字 -->
08. <filter-name>struts2</filter-name>
09. <!-- 配置Struts2核心Filter的实现类 -->
10. <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
11. <init-param>
12. <!-- 配置Struts2框架默认加载的Action包结构,可以没有。 -->
13. <param-name>actionPackages</param-name>
14. <param-value>org.apache.struts2.showcase.person</param-value>
15. </init-param>
16. <!-- 配置Struts2框架的配置提供者类 -->
17. <init-param>
18. <param-name>configProviders</param-name>
19. <param-value>lee.MyConfigurationProvider</param-value>
20. </init-param>
21. </filter>
22. <!-- 配置Filter拦截的URL -->
23. <filter-mapping>
24. <!-- 配置Struts2的核心FilterDispatcher拦截所有用户请求 -->
25. <filter-name>struts2</filter-name>
26. <url-pattern>/*</url-pattern>
27. </filter-mapping>
28.
29. <welcome-file-list>
30. <welcome-file>index.html</welcome-file>
31. </welcome-file-list>
32. </web-app>
*如上,当配置Struts2的FilterDispatcher类时,可以指定一系列的初始化参数,为该Filter配置初始化参数时,其中有3个初始化参数有特殊意义:
config:使用逗号隔开的字符串,每个字符串都是一个XML配置文件的位置。Struts框架将自动加载该属性指定的系列配置文件。
actionPackages:使用逗号隔开的字符串,每个字符串都是一个包空间,Struts2框架将扫描这些包空间下的Action。
configProviders:配置自己的ConfigurationProvider类。
还可以在此处配置Struts2常量,每个<init-param>元素配置一个Struts2常量,其中<param-name>子元素指定了常量name,而<param-value>子元素指定了常量value。
*在web.xml中配置了<Filter>元素,还需要配置该Filter拦截的URL。通常,我们让该Filter拦截所有的用户请求。可以能过<filter-mapping>元素配置。
转自:http://www.iteye.com/topic/175029
hibernate是简化访问数据库的orm工具 web.xml是用来配置web应用的 两者完全不搭界的
(1)问题:如何在Web项目中配置spring的IoC容器?
答:如果需要在Web项目中使用Spring的IoC容器,可以在Web项目配置文件web.xml中做出如下配置:
<!-- Spring监听器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
---------------------------------------------------------------------------------------------------------------------------------------------------
(2)如何在Web项目中配置Spring MVC?
答:要使用Spring MVC需要在Web项目配置文件中web.xml中配置其 前端控制器DispatcherServlet:
<!-- Spring MVC servlet -->
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/spring-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
===============================================================================================================
spring-mvc.xml 文件内容:
<?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:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.1.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
<!-- 自动扫描该包,使SpringMVC认为包下用了@controller注解的类是控制器 -->
<mvc:annotation-driven/>
<mvc:default-servlet-handler/>
<context:component-scan base-package="com.XXXX.controller">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" />
</context:component-scan>
<!-- 定义跳转的文件的前后缀 ,视图模式配置-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/"/>
<property name="suffix" value=".jsp"/>
</bean>
<!-- 启用默认配置 -->
<mvc:annotation-driven>
<mvc:message-converters register-defaults="true">
<!-- 配置Fastjson支持 -->
<bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter">
<property name="supportedMediaTypes">
<list>
<value>application/json</value>
<value>text/html;charset=UTF-8</value>
</list>
</property>
</bean>
</mvc:message-converters>
</mvc:annotation-driven>
<!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 -->
<bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 默认编码 -->
<property name="defaultEncoding" value="utf-8"/>
<!-- 文件大小最大值 -->
<property name="maxUploadSize" value="1048576000"/>
<!-- 内存中的最大值 -->
<property name="maxInMemorySize" value="10240"/>
</bean>
</beans>
===============================================================================================================
所以 <mvc:annotation-driven> 标签主要是用来帮助我们 处理请求映射,决定是哪个controller的哪个方法来处理当前请求,异常处理。
<context:component-scan/>标签:
它的实现类是org.springframework.context.annotation.ComponentScanBeanDefinitionParser.
用来扫描该包内被@Repository @Service @Controller的注解类,然后注册到工厂中。
并且context:component-scan激活@ required。@ resource,@ autowired、@PostConstruct @PreDestroy @PersistenceContext @PersistenceUnit。使得在适用该bean的时候用@Autowired就行了。主要用于对实体的注解交给spring容器管理
==============================================================================================
<annotaion-driven/>标签:包含以下两个实例:
RequestMappingHandlerMapping 处理@RequestMapping注解的
RequestMappingHandlerAdapter 处理@Controller注解的控制器类