[TOC]
# Hello SpringMVC
## 簡介
Spring Web MVC 是一種基于 Java 的實現了 Web MVC 設計模式的請求驅動類型的輕量級 Web 框架,即使用了 MVC 架構模式的思想,將 Web 層進行職責解耦,基于請求驅動指的就是使用**請求-響應**模型,框架的目的就是幫助我們簡化開發,Spring Web MVC 可以簡化日常 Web 開發。
## Spring Web MVC 能幫我們做什么
* 讓我們能非常簡單的設計出干凈的 Web 層和薄薄的 Web 層;
* 進行更簡潔的 Web 層的開發;
* 天生與 Spring 框架集成(如 IoC 容器、AOP 等);
* 支持靈活的 URL 到頁面控制器的映射;
> 基于框架的程序要成功運行,對于JAR包的版本,配置文件的正確性有著苛刻的要求,任何一個地方出錯了,都會導致框架程序運行失敗。
>
> 技巧: 學習框架,**務必嚴格按照教程的指導,完全模仿操作**,直到成功看到運行效果。 第一次成功之后,信心,思路都會有較好的鋪墊,然后再根據自己的疑惑,在“成功”的代碼上做原本想做的改動和調整,這樣可以大大節約學習的時間,提高效率,**切勿一來就擅自改動**,給自己的學習制造障礙。
## 步驟 1 : 先運行,看到效果,再學習
Spring MVC需要做不少步驟,任何一步部做漏了,做錯了,都有可能失敗,這樣會影響學習的信心,并且誤以為本教程是走不通的。
先可運行項目 springmvc.rar(向老師要相關資料),解壓后導入到eclipse中,啟動Tomcat,觀察是否正常運行。確定可以運行,確定教程是可以跑得起來的,再學習下面的內容。
部署成功自后,測試地址,應該看到如圖所示的效果
`http://localhost:8080/springmvc/index`

## 步驟 2 : 模仿和排錯
在確保可運行項目能夠正確無誤地運行之后,再嚴格照著教程的步驟,對代碼模仿一遍。
模仿過程難免代碼有出入,導致無法得到期望的運行結果,此時此刻通過比較**正確答案** ( 可運行項目 ) 和自己的代碼,來定位問題所在。
采用這種方式,**學習有效果,排錯有效率**,可以較為明顯地提升學習速度,跨過學習路上的各個檻。
## 步驟 3 : 創建項目springmvc
在eclipse中新建項目springmvc,使用dynamic web project的方式。

## 步驟 4 : 導入jar包
拿到lib.rar(向老師要相關資料),并解壓拷貝jar放到lib文件夾中;
> 使用老師提供的jar包,因為不同的jar包,因版本的不同,會導致**兼容性問題**。
## 步驟 5 : web.xml
配置Spring MVC的入口 DispatcherServlet,把所有的請求都提交到該Servlet
注意:`<servlet-name>springmvc</servlet-name>`
springmvc這個名字在下一步會用到。
~~~
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>springmvc</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>
org.springframework.web.servlet.DispatcherServlet
</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
~~~
## 步驟 6 : 創建springmvc-servlet.xml
在WEB-INF目錄下創建 springmvc-servlet.xml
springmvc-servlet.xml 與上一步中的
`<servlet-name>springmvc</servlet-name>`
springmvc對應
~~~
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
<bean id="simpleUrlHandlerMapping"
class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name="mappings">
<props>
<prop key="/index">indexController</prop>
</props>
</property>
</bean>
<bean id="indexController" class="com.dodoke.controller.IndexController"></bean>
</beans>
~~~
這是Spring MVC的**映射配置文件**
表示訪問路徑/index會交給`id=indexController`的bean處理
`id=indexController`的bean配置為類:IndexController。
## 步驟 7 : 控制類 IndexController
控制類 IndexController實現接口Controller ,提供方法handleRequest處理請求
SpringMVC通過 ModelAndView 對象把模型和視圖結合在一起。
~~~
package com.dodoke.controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
public class IndexController implements Controller {
@Override
public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
ModelAndView mav = new ModelAndView("index.jsp");
mav.addObject("message", "Hello SpringMVC");
return mav;
}
}
~~~
> ModelAndView注意引用正確的包。
> import org.springframework.web.servlet.ModelAndView; //正確
import org.springframework.web.portlet.ModelAndView; //錯誤
## 步驟 8 : 準備index.jsp
在WebContent目錄下創建index.jsp
index.jsp很簡單,通過EL表達式顯示message的內容

~~~
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>${message }</h1>
</body>
</html>
~~~
## 步驟 9 : 部署在tomcat中,重啟測試
部署在Tomcat中,重啟tomcat,然后訪問地址,觀察效果
`http://localhost:8080/springmvc/index`

## 步驟 10 : 原理圖
1. 用戶訪問 /index
2. 根據web.xml中的配置 所有的訪問都會經過DispatcherServlet
3. 根據配置文件springmvc-servlet.xml ,訪問路徑/index,會進入IndexController類
4. 在IndexController中指定跳轉到頁面index.jsp,并傳遞message數據
5. 在index.jsp中顯示message信息

> 一般說來,根據步驟一步一步的做過來,就可以運行看到結果了。
如果實在看不到結果,多半是因為中間某個步驟不夠仔細,大小寫錯誤,多了個下劃線等等細微的錯誤。
## 常見問題
1. 為什么加載index.jsp請求不到后臺的數據,而請求index就可以
> 訪問index路徑發出請求,springmvc通過這個請求進入對應的控制器,在控制器里面將視圖和模型結合起來,也就是index.jsp和message,最后跳轉到index.jsp界面,這個界面上的數據就是message的內容。
>`${message}` 這里,message這個數據模型是從控制器里拿出來再放到index.jsp上。如果直接訪問index.jsp這個靜態資源,是無法取得后臺數據。
>
>補充說明:根據`<prop key="/index">indexController</prop>` ,搜index的時候,會交給`<bean id="indexController" class="com.dodoke.controller.IndexController"></bean>`也就是IndexController類處理,IndexController實現接口Controller ,提供方法handleRequest處理請求。
2. 為什么根據“springmvc-servlet.xml”這個文件的命名就可以對應到springmvc?
> 是的,這里的命名規則是{servlet-name}-servlet.xml。你在web.xml里的servlet-name是什么就查找對應的文件。
3. `<url-pattern>/</url-pattern>`的 / 是什么意思,以前用的是/*,這個是指任意訪問路徑吧?那 / 表示什么意思呢?
> /* 可以攔截一切路徑,比如 index, index.jsp, index.html這些都可以被攔截
/ 只能攔截url請求路徑,也就是index這種,帶有后綴名的就不能被攔截
4. 此處的message是對象?有一個屬性值是hello spring mvc?然后在index.jsp獲得這個屬性值?但EL表達式是${message}很像從session中取值的樣子
> 這是把message設置在request作用域中,然后服務端跳轉到index.jsp,之后利用EL表達式取值。
- 前言
- 計算機概論
- MySQL數據庫
- 數據庫介紹
- MySQL的安裝
- SQL
- 表基本操作
- 修改數據語句
- 數據檢索操作
- 多表數據操作
- 表結構設計
- 綜合應用
- SQL-SERVER
- 數據庫介紹
- SQL-SERVER安裝
- SQL
- 表基本操作
- JAVA
- JAVA 介紹
- JAVA 運行原理
- JDK 配置
- 類和對象
- 數據類型
- 變量
- 直接量
- 運算符
- 流程控制
- 數組結構
- 面向對象
- 隱藏和封裝
- 深入構造器
- 類的繼承
- 多態
- 包裝類
- final 修飾符
- 抽象類
- 接口
- 集合框架
- 常用類學習
- 異常處理
- 設計模式-單例模式
- JDBC
- HTML基礎
- Web原理和HTML簡介
- Web原理
- HTML概念
- HTML標簽
- 標簽
- HTML固定基本結構
- 第一個HTML頁面
- 工具的使用
- 標題
- hr和p標簽
- 路徑概念
- 超級鏈接
- 列表
- 表格
- 表單的設計與使用
- 表單域的原理
- 文本框和密碼框
- 單選框和復選框
- 下拉列表框
- 多行文本和上傳
- 提交按鈕和重置按鈕
- 為CODING COFFEE加入在線購買頁
- HTML5
- 定位服務
- CSS基礎
- CSS的基礎使用
- CSS簡介
- CSS樣式規則和加載方式
- 內聯元素和區塊元素介紹
- 選擇器
- 偽類
- CSS顏色
- 背景圖片
- 文本
- CSS列表
- DIV+CSS布局
- 盒子模型的邊距和邊框
- Display屬性
- 浮動和清除浮動
- 用Position屬性進行定位
- 專題:居中和對齊
- CSS新特性
- CSS3邊框
- 動畫
- JavaScript基礎
- Hello World!
- 語句和變量
- 一切皆對象
- 標識符、注釋和區塊
- 基本數據類型和引用數據類型
- 語句
- 條件語句
- 循環語句
- 數據類型
- typeof
- number
- 字符串
- 布爾類型
- 函數
- 數組
- 運算符
- 加法運算符
- 算術、賦值、比較運算符
- 布爾運算符
- DOM模型
- DOM和DOM節點
- 特征相關屬性
- 節點對象的方法
- Element對象
- Attribute對象
- Text節點和CSS操作
- 事件模型
- 標準庫
- Number對象
- String對象
- Array對象
- Date、Boolean和Math對象
- JSON對象
- 面向對象編程中的 this
- Web Storage
- 錯誤處理機制
- Error對象和try..catch語句
- javascript的原生錯誤類型
- BOM模型
- window對象
- 計時事件
- jQuery基礎
- 認識jQuery
- jQuery對象和DOM對象
- jQuery選擇器
- jQuery Dom操作
- 查找節點和創建節點
- 插入節點和刪除節點
- 復制節點和替換節點
- 包裹節點和屬性操作
- 樣式操作
- 設置和獲取HTML、文本和值
- 遍歷節點和CSS操作
- jQuery 事件和動畫
- 事件綁定與冒泡處理
- jQuery動畫
- jQuery 插件
- validate 插件
- jQuery與Ajax的應用
- Ajax簡介
- jquery中的Ajax
- Flex布局
- Flexbox介紹
- 伸縮容器屬性介紹
- dispaly屬性
- flex-direction屬性
- flex-wrap屬性
- flex-flow屬性
- align-content屬性
- justify-content屬性
- align-items屬性
- 伸縮項目屬性介紹
- order屬性
- grow屬性
- basis屬性
- shrink屬性
- flex屬性簡寫
- align-self屬性
- Bootstrap基礎
- 起步
- 柵格系統
- 排版樣式
- 表格和按鈕
- 表單和圖片
- 輔助類和響應式工具
- 圖標菜單按鈕組件
- 輸入框和導航組件
- 路徑、分頁、標簽和徽章組件
- 巨幕、頁頭、縮略圖和警告框
- 進度、條媒體對象和Well組件
- 列表組和嵌入組件
- Canvas
- Canvas坐標體系
- Canvas畫布大小設置
- Canvas畫直線
- Canvas畫圓和矩形
- Canvas描邊與填充
- Canvas圖形變換
- Canvas線性漸變
- Canvas徑向漸變
- Canvas中的文字
- Canvas圖片繪制
- Canvas圖形畫刷
- Canvas剪輯區域
- Canvas繪制陰影
- Canvas繪制曲線
- Canvas動畫
- Canvas離屏操作
- 微信小程序
- 起步
- 小程序目錄
- 小程序配置
- 新建頁面
- WXML
- 組件
- 視圖容器
- 基礎內容
- 表單組件
- button
- checkbox
- form
- input
- label
- picker
- picker-view
- radio
- slider
- switch
- textarea
- 導航
- 媒體組件
- audio
- image
- video
- camera
- live-player
- live-pusher
- 地圖
- 畫布
- 數據綁定
- 運算
- 組合
- 列表渲染
- 條件渲染
- 模板
- 事件
- WXSS
- JS
- JSP&Servlet
- Web應用
- Tomcat
- JSP
- Scriptlet
- Page 指令
- 包含指令
- 跳轉指令
- 用戶注冊實例
- JSP練習
- 內置對象
- Servlet
- 過濾器
- Web分層思想
- EL表達式
- JSTL
- 分頁實現
- AJAX&JSON
- 開發步驟
- 路徑問題
- Log4j
- 電子書城
- 案例分析
- 核心代碼
- Java高級
- 文件操作
- 泛型
- 類加載機制和反射
- 注解 Annotation
- Mybatis框架
- 框架介紹
- Mybatis簡單實現
- 表基本操作
- 優化配置文件
- 表字段名與實體類屬性名不同的解決方案
- 一對一關聯
- 一對多關聯
- Spring框架
- IOC/DI
- 注入對象
- 注解方式 IOC/DI
- AOP
- 注解方式AOP
- 注解方式測試
- Spring MVC框架
- Hello SpringMVC
- 視圖定位
- 注解方式
- 接受表單數據
- 客戶端跳轉
- Session
- 中文問題
- 上傳文件
- SSM整合
- 整合步驟
- 分頁
- PageHelper
- 連接池
- CRUD
- 事務管理
- JSON
- Maven
- 介紹
- 下載與配置MAVEN
- MAVEN倉庫
- ECLIPSE中的MAVEN設置
- ECLIPSE下創建MAVEN風格的JAVA項目
- 添加JAR包
- 創建MAVEN風格的JAVA WEB項目
- 創建SSM項目
- 使用ECLIPSE導入一個MAVEN風格的SSM項目
- 教學管理模版
- 學員名錄
- 周測統計
- 2017-10-27
- 課堂作業
- 班會紀要
- 2017-10-24
- 缺勤記錄
- 班級備忘錄
- 違紀統計