第一個MVC程式
HelloSpringMVC
配置版
1、建立一個Module,springmvc-02-hello,添加web的支援
2、确定導入了SpringMVC的依賴!
3、配置web.xml,注冊DispatcherServlet
<?xml version="1.0" encoding="UTF-8"?>
<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的配置檔案:【servlet-name】-servlet.xml-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-servlet.xml</param-value>
</init-param>
<!--啟動級别-1-->
<load-on-startup>1</load-on-startup>
</servlet>
<!--/ 比對所有的請求;(不包括.jsp)-->
<!--/* 比對所有的請求;(包括.jsp)-->
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
4、編寫SpringMVC的配置檔案!名稱:springmvc-servlet.xml : [servletname]-servlet.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"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
</beans>
5、添加 處理器映射器(可以省略,會自動配置)
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
6、添加處理器擴充卡(可以省略,會自動配置)
<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
7、添加視圖解析器
<!--視圖解析器:DispatcherServlet給他的ModelAndView-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="InternalResourceViewResolver">
<!--字首-->
<property name="prefix" value="/WEB-INF/jsp/"/>
<!--字尾-->
<property name="suffix" value=".jsp"/>
</bean>
8、編寫我們要操作的業務Controller,要麼實作Controller接口,要麼增加注解;需要傳回一個ModelAndView,裝資料,封視圖;
package com.edgar.controller;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
// 注意:這裡我們先實作Controller接口
public class HelloController implements Controller {
public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
//ModelAndView 模型和視圖
ModelAndView mv = new ModelAndView();
//封裝對象,放在ModelAndView中。
mv.addObject("msg","HelloSpringMVC!");
//封裝要跳轉的視圖,放在ModelAndView中
mv.setViewName("hello"); //: /WEB-INF/jsp/hello.jsp
return mv;
}
}
9、将自己的類交給SpringIOC容器,注冊bean
<!--Handler-->
<bean id="/hello" class="com.edgar.controller.HelloController"/>
10、寫要跳轉的hello.jsp頁面顯示ModelAndView存放的資料,以及我們的正常頁面;
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
${msg}
</body>
</html>
11、配置Tomcat 啟動測試!

可能遇到的問題:通路出現404,排查步驟:
- 檢視控制台輸出,看一下是不是缺少了什麼jar包。
- 如果jar包存在,顯示無法輸出,就在IDEA的項目釋出中,添加lib依賴!
- 重新開機Tomcat 即可解決!
小結:看這個估計大部分同學都能了解其中的原理了,但是我們實際開發才不會這麼寫,不然就瘋了,還學這個玩意幹嘛!我們來看個注解版實作,這才是SpringMVC的精髓,到底有多麼簡單,看這個圖就知道了。
注解版
1、建立一個Moudle,springmvc-03-hello-annotation 。添加web支援!
2、由于Maven可能存在資源過濾的問題,我們将配置完善
<build>
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
</build>
3、在pom.xml檔案引入相關的依賴:主要有Spring架構核心庫、Spring MVC、servlet , JSTL等。我們在父依賴中已經引入了!
4、配置web.xml
<?xml version="1.0" encoding="UTF-8"?>
<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.注冊servlet-->
<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攔截 -->
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
注意點:
- 注意web.xml版本問題,要最新版!
- 注冊DispatcherServlet
- 關聯SpringMVC的配置檔案
- 啟動級别為1
- 映射路徑為 / 【不要用/*,會404】
/ 和 /* 的差別:< url-pattern > / </ url-pattern > 不會比對到.jsp, 隻針對我們編寫的請求;即:.jsp 不會進入spring的 DispatcherServlet類 。< url-pattern > /* </ url-pattern > 會比對 *.jsp,會出現傳回 jsp視圖 時再次進入spring的DispatcherServlet 類,導緻找不到對應的controller是以報404錯。
5、添加Spring MVC配置檔案
在resource目錄下添加springmvc-servlet.xml配置檔案,配置的形式與Spring容器配置基本類似,為了支援基于注解的IOC,設定了自動掃描包的功能,具體配置資訊如下:
<?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.edgar.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>
在視圖解析器中我們把所有的視圖都存放在/WEB-INF/目錄下,這樣可以保證視圖安全,因為這個目錄下的檔案,用戶端不能直接通路。
- 讓IOC的注解生效
- 靜态資源過濾 :HTML . JS . CSS . 圖檔 , 視訊 .....
- MVC的注解驅動
- 配置視圖解析器
6、建立Controller
編寫一個Java控制類:com.edgar.controller.HelloController , 注意編碼規範
package com.edgar.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping("/HelloController")
public class HelloController {
// 真實通路位址 : 項目名/HelloController/hello
@RequestMapping("/hello")
public String hello(Model model) {
// 向模型中添加屬性msg與值,可以在JSP頁面中取出并渲染
model.addAttribute("msg", "Hello,SpringMVCAnnotation!");
// 會被視圖解析器處理 /WEB-INF/jsp/hello.jsp
return "hello";
}
}
- @Controller是為了讓Spring IOC容器初始化時自動掃描到;
- @RequestMapping是為了映射請求路徑,這裡因為類與方法上都有映射是以通路時應該是/HelloController/hello;
- 方法中聲明Model類型的參數是為了把Action中的資料帶到視圖中;
- 方法傳回的結果是視圖的名稱hello,加上配置檔案中的前字尾變成/WEB-INF/jsp/hello.jsp。
7、建立視圖層
在WEB-INF/ jsp目錄中建立hello.jsp , 視圖可以直接取出并展示從Controller帶回的資訊;
可以通過EL表達示取出Model中存放的值,或者對象;
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
${msg}
</body>
</html>
8、配置Tomcat運作
OK,運作成功!
小結
實作步驟其實非常的簡單:
- 建立一個web項目
- 導入相關jar包
- 編寫web.xml , 注冊DispatcherServlet
- 編寫springmvc配置檔案
- 接下來就是去建立對應的控制類 , controller
- 最後完善前端視圖和controller之間的對應
- 測試運作調試.
使用springMVC必須配置的三大件:
處理器映射器、處理器擴充卡、視圖解析器
通常,我們隻需要手動配置視圖解析器,而處理器映射器和處理器擴充卡隻需要開啟注解驅動即可,而省去了大段的xml配置