特点:
1.轻量级,简单易学
2.高效,基于请求相应的MVC框架
3.与Spring兼容性好,无缝结合
4.约定大于配置
5.功能强大:RESTful、数据验证、格式化、本地化、主题等
6.简洁灵活
SpringMVC开发步骤
回顾Servlet
步骤:
1.编写页面文件,设置跳转的服务器地址
2.编写Servlet程序,处理用户请求,调用相关业务模型,并进行用户响应
3.建立URL与Servlet的映射,有两种方式:
第一种是使用WEB-INF目录下的web.xml配置映射关系
第二种是在Servlet类加上注解
使用Controller类开发SpringMVC步骤
1.配置web.xml文件,注册DispatcherServlet,关联SprimgMVC核心配置文件,建立Servlet映射
2.配置SpringMVC核心文件,设置注解自动扫描,注解驱动,让SpringMVC不处理静态资源,配置视图解析器,关联Controller类
3.建立Controller类,加上注解@Controller,关联视图解析器
4.配置Tomcat,进行网页测试
使用注解开发SpringMVC步骤
1.配置web.xml文件,注册DispatcherServlet,关联SprimgMVC核心配置文件,建立Servlet映射
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0"> <!--1.注册DispatcherServlet,请求分发,前端控制器--> <servlet> <servlet-name>SpringMVC</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!--通过初始化参数指定SpringMVC配置文件的位置,进行关联--> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:springmvc-servlet.xml</param-value> </init-param> <!-- 启动顺序,数字越小,启动越早 --> <load-on-startup>1</load-on-startup> </servlet> <!--所有请求都会被springmvc拦截 --> <!--/:匹配所有请求,但不匹配.jsp --> <!--/*:匹配所有请求,但不匹配.jsp --> <servlet-mapping> <servlet-name>SpringMVC</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>
2.配置SpringMVC核心文件,设置注解自动扫描,注解驱动,让SpringMVC不处理静态资源,配置视图解析器,关联Controller类
<?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.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!-- 自动扫描包,让指定包下的注解生效,由IOC容器统一管理 --> <context:component-scan base-package="com.kuang.controller"/> <!-- 让Spring MVC不处理静态资源 --> <mvc:default-servlet-handler /> <!-- 支持mvc注解驱动 在spring中一般采用@RequestMapping注解来完成映射关系 要想使@RequestMapping注解生效 必须向上下文中注册DefaultAnnotationHandlerMapping 和一个AnnotationMethodHandlerAdapter实例 这两个实例分别在类级别和方法级别处理。 而annotation-driven配置帮助我们自动完成上述两个实例的注入。 --> <!--注解驱动--> <mvc:annotation-driven /> <!-- 视图解析器 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver"> <!-- 前缀 --> <property name="prefix" value="/WEB-INF/jsp/" /> <!-- 后缀 --> <property name="suffix" value=".jsp" /> </bean> </beans>
3.建立Controller类,加上注解@Controller,关联视图解析器
package com.kuang.controller; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; @Controller @RequestMapping("/hello") public class HelloController { <!-- 映射请求,用来指定控制器可以处理哪些URL请求 --> @RequestMapping("/h1") public String hello(Model model){ model.addAttribute("msg","Hello,World!"); return "hello"; } }
4.配置Tomcat,执行访问测试