l应该是整个项目最重要的配置文件了,不过servlet3.0中已经支持注解配置方式了。在servlet3.0以前每个servlet必须要在l中配置servlet及其映射关系。但是在spring框架中就不用了,因为Spring中是依赖注入(Dependency Injection)的也叫控制反转(Inversion of Control)。但是也要配置一个重要的servlet,就是前端控制器(DispatcherServlet)。配置方式与普通的servlet基本相似。
配置内容如下:
<servlet>
    <servlet-name>spring</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <init-param>
        <!-- ContextconfigLocation配置springmvc加载的配置文件
        适配器、处理映射器等
        -->
        <param-name>contextConfigLocation</param-name>
        <param-value>WEB-INF/classes/l</param-value>
</init-param>
</servlet>
<servlet-mapping>
    <servlet-name>spring</servlet-name>
    <!-- 1、.action访问以.action结尾的  由DispatcherServlet进行解析
        2、/,所有访问都由DispatcherServlet进行解析
    -->
    <url-pattern>/</url-pattern>
</servlet-mapping>
这里需要注意,lspring配置文件,将在后面讨论。在<servlet-mapping>url如果是.action,前端控制器就只会拦截以.action结尾的请求,并不会理会静态的文件。对静态页面的控制就要通过其他的手段。以/作为url的话就会拦截所有的请求,包括静态页面的请求。这样的话就可以拦截任何想要处理的请求,但是有一个问题。如果拦截了所有的请求,如果不在中做出相应的处理那么所有静态的jscss以及页面中用到的图片就会访问不到造成页面无法正常显示。但这可以通过静态资源的配置来解决这个问题。后面会提到。
配置spring容器:
<context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>WEB-INF/classes/spring/applicationContext-*.xml</param-value>
</context-param>
其中applicationContext-*.xml包含3个配置文件,是springIoC容器的具体配置。后面会提到。
配置一个:
<listener>
      <listener-class>org.t.ContextLoaderListener</listener-class>
</listener>
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0"
    xmlns="java.sun/xml/ns/javaee"
    xmlns:xsi="/2001/XMLSchema-instance"
    xsi:schemaLocation="java.sun/xml/ns/javaee
    java.sun/xml/ns/javaee/web-app_3_0.xsd">
  <display-name></display-name>   
 
  <error-page>
    <error-code>404</error-code>
    <location>/error404.jsp</location>
  </error-page>
 
  <error-page>
    <error-code>500</error-code>
    <location>/error500.jsp</location>
  </error-page>
 
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>WEB-INF/classes/spring/applicationContext-*.xml</param-value>
    </context-param>
    <listener>
    <listener-class>org.t.ContextLoaderListener</listener-class>
    </listener>
 
  <servlet>
      <servlet-name>spring</servlet-name>
      <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
      <init-param>
          <!-- ContextconfigLocation配置springmvc加载的配置文件
          适配器、处理映射器等
          -->
          <param-name>contextConfigLocation</param-name>
          <param-value>WEB-INF/classes/l</param-value>
  </init-param>
  </servlet>
  <servlet-mapping>
      <servlet-name>spring</servlet-name>
      <!-- 1、.action访问以.action结尾的  由DispatcherServlet进行解析
          2、/,所有访问都由DispatcherServlet进行解析
      -->
      <url-pattern>/</url-pattern>
  </servlet-mapping>
 
  <filter>
      <filter-name>CharacterEncodingFilter</filter-name>
      <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
      <init-param>
          <param-name>encoding</param-name>
          <param-value>utf-8</param-value>
      </init-param>
  </filter>
  <filter-mapping>
      <filter-name>CharacterEncodingFilter</filter-name>
      <url-pattern>/*</url-pattern>
  </filter-mapping>
  <welcome-file-list>
    <welcome-file>welcome.jsp</welcome-file>
  </welcome-file-list>
</web-app>
看到配置文件中多了两块内容,一个是error page是用来友好的处理错误的,可以使用错误代码来区别并跳转到相应的处理页面。这段配置代码最好放到最前面,在前端控制器拦截之前处理。
还有一块内容是一个解决post乱码问题的过滤器,拦截post请求并编码为utf8
视图解析器的配置:
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
       
        <property name="prefix" value="/"></property>
        <property name="suffix" value=".jsp"></property>
spring ioc注解</bean>
Controller中设置视图名的时候会自动加上前缀和后缀。
Controller的配置
自动扫描方式,扫描包下面所有的Controller,可以使用注解来指定访问路径。
<context:component-scan base-package="com.ller">
也可以使用单个的配置方式,需要指定Controller的全限定名。
<bean name="/queryUser.action" class="com.ller.Controller1"/>
配置注解的处理器适配器和处理器映射器:
<bean class=
"org.springframework.web.hod.annotation.RequestMappingHandlerAdapter"/>
<bean class=
"org.springframework.web.hod.annotation.RequestMappingHandlerMapping"/>
也可以使用下面的简化配置:
<mvc:annotation-driven conversion-service="conversionService"></mvc:annotation-driven>

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。