Rumour-has-it

导航

SpringMVC核心组件记录

DispatcherServlet:前端控制器,主要职责是接收所有请求(根据配置文件来决定),并将请求转发给对应的控制器,接收控制器的处理结果,确定最终由哪个视图完成相应!
HandlerMapping:处理请求路径和控制器的映射关系。
Controller:实际处理请求的组件,例如接收请求参数,决定最终是转发或重定向的方式来响应。
ModelAndView:控制器的处理结果,其中的Model表示转发的数据(如果是重定向,则Model没有意义),而View表示最终负责响应的视图组件的名称。
ViewResolver:根据试图组件名称,确定具体使用的是哪个视图组件。
SpringMVC-HelloWorld
1. 创建项目
创建Maven Project,勾选Create a simple project,然后,Group Id值为cn.edu.spring(根据自己实际需要来决定),Artifact Id值为SPRINGMVC-01-HELLOWORLD(这个名称根据自己的实际来写),Packaging选择war:
接下来,需要执行4个步骤(以后每次创建项目时都需要做的事情):
  1. 生成web.xml文件;
  2. 添加依赖:在此前的项目中找到pom.xml,将其中的依赖的代码复制到当前项目中,关于依赖的jar包,会越用越多,学习时,只加不减;
  3. 复制spring.xml文件到当前项目中,并删除其中的配置,除非你确定这些配置是当前项目中必须使用的;
  4. 为项目添加Tomcat运行环境;
2. 配置DispatcherServlet
由于需要DispatcherServlet接收所有请求,所以,首先必须在web.xml配置它:
1
2
3
4
5
6
7
8
9
<!-- 配置DispatcherServlet --> 
<servlet>    
     <servlet-name>SpringMVC</servlet-name>    
     <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class
 </servlet
 <servlet-mapping>  
    <servlet-name>SpringMVC</servlet-name>   
    <url-pattern>*.com</url-pattern
 </servlet-mapping>
经过以上配置,则任何以.com作为后缀的请求,都将由DispatcherServlet来处理!
由于项目是基于Spring的,希望项目启动时就加载Spring的配置文件,并使得DispatcherServlet已经完成初始化可以随时接收请求,所以,还需进一步的配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<!-- 配置DispatcherServlet -->
<servlet>    
    <servlet-name>SpringMVC</servlet-name>    
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>    <!-- 配置spring的配置文件 -->    
    <init-param>        
        <param-name>contextConfigLocation</param-name>备注:这个name是源码中的,固定                
        <param-value>classpath:spring.xml</param-value>备注:值要看个人的配置文件的路径    
    </init-param>    
    <!-- 启动Tomcat时即初始化该Servlet -->    
    <load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>    
    <servlet-name>SpringMVC</servlet-name>    
    <url-pattern>*.com</url-pattern>
</servlet-mapping>
至此,当项目启动时,就会初始化DispatcherServlet,并且,在初始化过程中,会加载Spring的配置文件。
测试
如果Spring能正常工作,则配置是成功的!
在src\main\java中创建一个测试类cn.edu.spring.test.Test,并且,显式的添加构造方法,并输出内容:
1
2
3
4
5
@Component public class Test {
    public Test() {
        System.out.println("已经加载Spring配置文件!");    
    
}
然后,在Spring的配置文件中添加组件扫描:
1
<context:component-scan base-package="cn.edu.spring" />
最终,把项目部署到Tomcat,并启动Tomcat,在启动日志中如果能够看到以上输出语句,则成功!
3. 设计目标
发出请求http://localhost:8080/项目名称/hello.com,要求在界面中显示HelloWorld字样。
4. 处理请求
以上完成了流程中的第1步,接下来,如果发出hello.do请求,就会被DispatcherServlet接收得到,然后,DispatcherServlet应该根据hello.do请求路径去询问HandlerMapping得知由哪个控制器去处理请求,原始的实现方式是使用SimpleUrlHandlerMapping类去进行配置,不过,这种配置方式非常麻烦,而且,对应关系不明确(所有的路径与控制器的配置都在同一个配置文件中,导致不便于管理),所以,后续都是使用注解完成相关配置,则在开发过程中,跳过第2步和第3步(只是开发时不用关注,框架的执行流程不变)。
为了确保有控制器处理请求,所以,创建HelloController:
所有的控制器都应该是由Spring管理的,所以,需要为控制器类添加@Controller注解:
1
@Controllerpublic class HelloController {}
然后,在类中自定义处理请求的方法,方法的访问权限是public的,返回值暂时使用String,方法的名称可以自由定义,方法的参数暂时留空:
1
2
public String showHello() { 
}
在SpringMVC中,请求对应的可以是某个方法,而不一定每个请求对应一个控制器类,如果请求对应的是以上方法,则需要在方法的声明之前添加@RequestMapping("/hello.com"):
1
@RequestMapping("/hello.com")public String showHello() {}
完成以上步骤后,即表示:路径为/hello.com的请求将触发showHello()方法被执行!
测试
在以上方法中输出任意语句,然后,启动项目,请求对应的路径,观察控制台输出:
1
2
3
4
@RequestMapping("/hello.com")public String showHello() {
    System.out.println("HelloController.showHello()");
    return null;
}
实际运行效果是:页面会显示错误:
控制台可以看到输出语句:
5. 显示页面
至此,执行流程已经完成前4步,接下来,控制器应该向DispatcherServlet返回结果:
1
2
3
4
5
6
@RequestMapping("/hello.com")public String showHello() {
    // 测试    
    System.out.println("HelloController.showHello()");
    // 返回视图组件的名称
    return "helloworld";
}
以上返回的字符串表示最终负责显示的视图组件的名称,但是,并不表示是哪个文件!
接下来,需要配置ViewResolver,使得DispatcherServlet通过它可以知道刚才控制器返回的"helloworld"到底是哪个页面!
实际使用的ViewResolver是InternalResourceViewResolver,需要在spring.xml进行配置:
<!--配置视图解析器ViewResolver-->
1
2
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
</bean>
InternalResourceViewResolver的工作方式是以项目的根路径为参考(在开发时,对应的是webapp文件夹),使用前缀+视图组件名+后缀得到视图文件的位置,例如实际存在的jsp文件是webapp/WEB-INF/helloworld.jsp,由于它本身使用webapp作为根级,所以,前缀是/WEB-INF/,后缀是.jsp,结合控制器返回的"helloworld"进行拼接,就可以得到以上路径,从而确定视图组件的位置,例如配置为:
1
2
3
4
5
6
7
8
9
<!-- 配置视图解析器ViewResolver -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">    
    <!-- 配置前缀 -->    
    <property name="prefix" value="/WEB-INF/" />    
    <!-- 配置后缀 -->    
    <property name="suffix" value=".jsp" />    
    <!-- 经过以上配置后, -->    
    <!-- 当前项目中的jsp文件都应该放在/WEB-INF/下 -->
</bean>
基于视图解析器的前缀是/WEB-INF/,后缀是.jsp,结合控制器返回的"helloworld"字符串,则需要在WEB-INF文件夹下创建名为helloworld.jsp的文件完成最终的显示:
通过浏览器再次访问,实际效果应该是:

posted on 2021-03-02 15:06  Rumour-has-it  阅读(54)  评论(0编辑  收藏  举报