天天看点

SpringMVC框架基础知识(01)

1. SpringMVC框架的作用

MVC = Model(数据模型) + View(视图) + Controller(控制器),MVC思想是建议每个项目中至少有这3种核心的角色,用于处理不同的问题,其中,Model表示的数据处理,例如数据的增删改查等,View表示软件的界面,Controller表示控制器,用于接收客户端提交到服务器端的请求,并在处理完请求后给予客户端响应结果。

在不同的技术领域,这种思想可能也不同,例如在一些客户端软件的开发中,会使用MVP、MVVP等思想。

SpringMVC框架是基于Spring框架的,所以,在SpringMVC中,会使用到Spring框架的作用,例如通过Spring框架来创建对象、管理对象,也会使用到Spring框架中的一些注解。

SpringMVC框架主要解决了V-C交互的问题,即:客户端将请求提交到服务器后,肯定是由服务器端的控制器接收请求,SpringMVC就解决了如何接收请求(包含请求中的参数等)的问题,当服务器端处理完请求之后,应该给予客户端响应结果,SpringMVC也解决了如何响应的问题!事实上,SpringMVC框架与“M”完全没有任何关系,所以,在SpringMVC的学习过程中,完全不考虑数据的增删改查相关数据库技术。

2. 为什么要使用SpringMVC框架

……

3. SpringMVC HelloWorld

【案例目标】

写完项目后,运行项目,打开浏览器,输入http://localhost:8080/项目名称/hello.do即可看到预期显示的内容。

【准备工作】

在Eclipse中找到Servers面板,如果当前没有配置Tomcat,则点击该面板中的链接即可开始添加Tomcat!

如果Eclipse中没有显示Servers面板,则点击Window菜单的ShowView的Other选项,并在弹出的对话框输入Servers进行筛选,即可打开该面板!

在添加Tomcat的对话框中,结合本机中已有的Tomcat版本进行选择,然后,在对话框的第2个界面中浏览到本机的Tomcat文件夹,即可完全配置。

配置完成后,在Servers面板中就会出现刚才配置的Tomcat,同时,在项目列表中还会出现名为Servers的项目,该项目表示Tomcat的配置,在使用Tomcat的过程中,该项目必须是打开的,如果关闭了,Tomcat将无法启动!

【创建项目】

创建新的Maven Project,在创建过程中勾选Create a simple project,Group Id填为cn.tedu,Artifact Id填为springmvc01,Packaging必须选择war。

如果创建的项目是客户端项目,是通过某个类的main()方法启动的项目,应该选择jar;如果创建的项目是服务器端项目,是需要运行在Tomcat上的,就要选择war。

在Eclipse中,创建的war项目默认会报错,因为在项目中缺少web.xml文件,但是,war项目并不一定需要该文件!可以在pom.xml中添加以下配置:

<properties>
    <failOnMissingWebXml>false</failOnMissingWebXml>
</properties>      

当然,以上配置也可以结合关于开发、编译版本的配置为:

<properties>
    <failOnMissingWebXml>false</failOnMissingWebXml>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
</properties>      

并且,继续在pom.xml中添加spring-webmvc的依赖:

<dependencies>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-webmvc</artifactId>
        <version>5.2.5.RELEASE</version>
    </dependency>
</dependencies>      

最后,对项目点右键,选择Properties,并在弹出的项目属性对话框中,左侧选择Targeted Runtimes,在右侧勾选Tomcat。

【使用SpringMVC框架处理请求】

首先,在项目中创建cn.tedu.spring包,用于存放相关文件;

然后,自定义某个类(类名可以自定义),继承自AbstractAnnotationConfigDispatcherServletInitializer类:

package cn.tedu.spring;
import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;
public class SpringMvcInitializer extends
    AbstractAnnotationConfigDispatcherServletInitializer {
    @Override
    protected Class<?>[] getRootConfigClasses() {
  // TODO Auto-generated method stub
  return null;
    }
    @Override
    protected Class<?>[] getServletConfigClasses() {
  // TODO Auto-generated method stub
  return null;
    }
    @Override
    protected String[] getServletMappings() {
  // TODO Auto-generated method stub
  return null;
    }
}      

由于AbstractAnnotationConfigDispatcherServletInitializer是抽象类,所以,继承之后,需要重写其中的3个抽象方法:

getRootConfigClasses():获取Spring的配置类,在简单的SpringMVC项目中,也许并不需要编写任何Spring环境的配置,则该方法返回null即可,后续,如果整合MyBatis框架或其它框架时,可能需要编写相关配置;

getServletConfigClasses():获取SpringMVC的配置类,SpringMVC的配置类可以自定义,且必须实现WebMvcConfigurer接口;

getServletMappings():获取框架所处理的请求的路径,假设所有以.do为后缀的请求都需要被SpringMVC框架处理,则可以配置为*.do。

例如,可以将以上方法重写为:

package cn.tedu.spring;

import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;

public class SpringMvcInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {

    @Override
    protected Class<?>[] getRootConfigClasses() {
        return null;
    }

    @Override
    protected Class<?>[] getServletConfigClasses() {
        return new Class[] { SpringMvcConfigurer.class };
    }

    @Override
    protected String[] getServletMappings() {
        return new String[] { "*.do" };
    }

}

      

以上SpringMvcInitializer类的作用就类似于web.xml的作用!例如,后续,当项目中需要使用到Filter组件时,也可以在这个类中添加配置!

接下来,在SpringMVC的配置类SpringMvcConfigurer的声明之前配置组件扫描:

package cn.tedu.spring;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@ComponentScan("cn.tedu.spring")
public class SpringMvcConfigurer implements WebMvcConfigurer {
}      

注意:在SpringMVC项目中,组件扫描必须配置在SpringMVC的配置类之前,不可以只配置在Spring的配置类之前!

在原生的Java EE技术中,控制器类就是一个个自定义的Servlet类,需要继承自HttpServlet的!而在SpringMVC项目中,控制器类不需要继承自某个特定的类,也不需要实现任何接口,仅有的要求是:

必须放在组件扫描的包中;

必须添加@Controller注解。

如果需要SpringMVC框架处理某个路径的请求,需要在控制器类中自定义方法,然后在方法内部编写代码进行处理,关于方法的声明:

在方法的声明之前添加@RequestMapping注解,用于配置处理哪个路径的请求;

应该使用public权限;

返回值类型暂时使用String类型;

方法的名称可以自定义;

方法的参数列表暂时为空。