文章目錄
- SpringMVC
-
- SpringMVC簡介
- SpringMVC與JSP、Servlet程式的差別
- SpringMVC快速入門
-
- 第一步:引入依賴
- 第二步:建立歡迎頁擷取使用者請求
- 第三步:配置渲染頁
- 第四步:定義handler,類似于一個個servlet
- 第五步:注冊DispatcherServlet
- 第六步:配置SpringMVC
SpringMVC
SpringMVC簡介
springmvc全稱是spring web mvc,是spring架構一部分,是一個mvc的架構,和struts2一樣是一個表現層架構。

SpringMVC與JSP、Servlet程式的差別
JSP+Servlet處理流程
SpringMVC處理流程
1、使用者發送請求至前端控制器DispatcherServlet
2、DispatcherServlet收到請求調用HandlerMapping處理器映射器查找Handler。
3、處理器映射器根據請求url找到具體的處理器,生成處理器對象及處理器攔截器(如果有則生成)一并傳回給DispatcherServlet。
4、DispatcherServlet通過HandlerAdapter處理器擴充卡調用處理器
5、HandlerAdapter調用處理器Handler
6、Handler執行完成傳回ModelAndView
7、HandlerAdapter将Handler執行結果ModelAndView傳回給DispatcherServlet
8、DispatcherServlet将ModelAndView傳給ViewReslover視圖解析器,ViewReslover根據邏輯視圖名解析View
9、ViewReslover傳回View
10、DispatcherServlet對View進行渲染視圖(即将模型資料填充至request域)。
11、DispatcherServlet響應使用者
SpringMVC快速入門
第一步:引入依賴
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<spring.version>5.1.5.RELEASE</spring.version>
</properties>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
第二步:建立歡迎頁擷取使用者請求
<%@ page contentType="text/html;charset=UTF-8" language="java"
pageEncoding="UTF-8" %>
<html>
<head>
<title>Hello SpringMVC</title>
</head>
<body>
<pre>
<a href="a" target="_blank" rel="external nofollow" >SpringMVC測試</a>
<a href="b" target="_blank" rel="external nofollow" >SpringMVC apple測試</a>
<a href="c" target="_blank" rel="external nofollow" >SpringMVC google測試</a>
<a href="d" target="_blank" rel="external nofollow" >測試ResponseBody</a>
</pre>
</body>
</html>
第三步:配置渲染頁
<%--
Created by IntelliJ IDEA.
User: lx
Date: 2019/6/28
Time: 17:55
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java"
pageEncoding="UTF-8"%>
<html>
<head>
<title>Hello</title>
</head>
<body>
<%
String key = (String)request.getAttribute("key");
%>
歡迎來到SpringMVC,敵軍還有xxxxx
<br />
參數值: <%=key%>
</body>
</html>
第四步:定義handler,類似于一個個servlet
package com.lanou3g.springmvc.web;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView;
/*
* 通過@Controller标注的類會被SpringIOC容器掃面和管理
* */
@Controller
public class HelloAction {
/*
* 定義一個Handler,可以處理http://localhost:8080/springmvc/test/hello
* */
@RequestMapping("a")
public String hello() {
System.out.println("進入HelloAction.hello()方法");
return "hello";
}
/*
* 處理請求,并攜帶資料跳轉到頁面
* @param mv
* @return
* */
@RequestMapping("b")
public ModelAndView hello1(ModelAndView mv) {
System.out.println("進入HelloAction.hello1()方法");
mv.setViewName("hello");
mv.addObject("key", "apple");
return mv;
}
@RequestMapping("c")
public String hello2() {
System.out.println("進入HelloAction.hello2()方法");
return "hello";
}
/**
* 通過@ResponseBody注解标注的方法, 不會被解析成視圖, 而是直接将傳回的内容本身輸出給調用方(浏覽器、其他服務、抓包工具)
*
* @return
*/
@ResponseBody
@RequestMapping("d")
public String test() {
return "sihuo";
}
}
第五步:注冊DispatcherServlet
在web.xml中添加:
<!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" >
<web-app>
<display-name>Archetype Created Web Application</display-name>
<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--指定SpringMVC配置檔案的位置,DispatcherServlet初始化時會初始化Spring上下文(WebApplicationContext)-->
<!-- 預設配置檔案尋找位置:/WEB-INF{Servlet-name}-servlet.xml,如果名字元合預設尋找規則,可以指定不配置檔案路徑-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/dispatcher-servlet.xml</param-value>
</init-param>
<!--配置容器啟動時初始化DispatcherServlet-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
關于DispatcherServlet攔截路徑:
1、
*.do
代表攔截所有以.do結尾的請求,例如:
/user/add.do
,弊端:所有的url都要以.do結尾。不會影響通路靜态檔案。
2、
/app/*
代表攔截/app/下面的任何路徑、檔案,例如:
/app/user/add
、
/app/user/add.jsp
(
在Action中配置的RequestMapping不需要包含/app
),弊端:請求的url都要包含/app
3、
/
代表将此Servlet設定為預設Servlet,它将攔截所有其他Servlet都無法攔截的請求,例如:
/user/add
、
/user/test/aa.js
,弊端:對jpg,js,css靜态檔案的通路也被攔截不能正常顯示(因為它覆寫了Tomcat給我們提供的專門用于處理靜态資源的Servlet)。後面有解決辦法。
4、
/*
攔截所有請求(包括*.jsp),可以走到Action中,但轉發到jsp時再次被攔截,不能通路到jsp。
注:
- 我們一般選擇将DispatcherServlet的攔截路徑配置成
或者指定字尾(如:
/
)。
*.action
- 我們配置攔截路徑是
時,為什麼jsp頁面不會被攔截,因為Tomcat中有專門處理*.jsp的Servlet
/
- Servlet攔截路徑的優先級是:完全路徑比對(/TestServlet) > 目錄比對(/aa/) > 擴充名比對(.do) > /(預設Servlet)
第六步:配置SpringMVC
配置dispacther-servlet.xml用于開啟注解掃描和配置視圖解析器
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
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
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 開啟掃描注解支援 -->
<context:component-scan base-package="com.lanou3g.springmvc.web"/>
<!-- 配置視圖解析器,用于将Handler方法中傳回的視圖名解析成真正可展示的頁面 -->
<mvc:view-resolvers> <!--InternalResourceViewResolver 内部資源視圖分解器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/"/>
<property name="suffix" value=".jsp"/>
</bean>
</mvc:view-resolvers>
</beans>