學習SpringMVC——從HelloWorld開始
雖然從學java的第一個程式——helloworld至今,已經有好幾個年頭了。當時自己找資料,看視訊,學習了java的輸入輸出流,多執行緒,網路程式設計等等, 而三大框架(Struts、Hibernate、Spring)基本只是開了個頭就出來實習了,尤其對於Spring更是沒有進行系統的學習, 雖然在實習的時候通過看專案,基本明白了spring mvc程式設計的框架是怎麼回事,遇到需求知道如何寫程式碼,在哪寫程式碼,但是還是缺乏一個系統的認識。對於涉及到一些spring的檔案配置或工作原理的問題時,就顯得有些侷促。所以,最近準備好好來學習下現如今在企業級開發中大行其道的Spring MVC。
什麼是Spring MVC
Spring MVC屬於SpringFrameWork的後續產品,已經融合在Spring Web Flow裡面。Spring 框架提供了構建 Web 應用程式的全功能 MVC 模組。使用 Spring 可插入的 MVC 架構,從而在使用Spring進行WEB開發時,可以選擇使用Spring的SpringMVC框架或整合其他MVC開發框架,如Struts1,Struts2等。
今天先從寫一個Spring MVC的HelloWorld開始,讓我們看看如何搭建起一個Spring mvc的環境並執行程式。
軟體引數
Eclipse:Mars.1 Release (4.5.1)
Tomcat: 8.0.36
JDK:1.8.0_60
Spring-framework: 4.0.4.RELEASE
新建專案
File-New-Other,選擇Dynamic web project
專案建好之後,目錄結構如下:
匯入jar包
我們基於Spring mvc框架進行開發,需要依賴一下的spring jar包:
- spring-aop-4.0.4.RELEASE.jar
- spring-beans-4.0.4.RELEASE.jar
- spring-context-4.0.4.RELEASE.jar
- spring-core-4.0.4.RELEASE.jar
- spring-expression-4.0.4.RELEASE.jar
- spring-web-4.0.4.RELEASE.jar
- spring-webmvc-4.0.4.RELEASE.jar
- commons-logging-1.1.1.jar(用來列印log)
在WEB-INF目錄下新建lib資料夾,並將上面的jar包放入其中。
jar包可以點選這裡下載。
配置檔案及編寫程式碼
web.xml(WEB-INF下)
1 <?xml version="1.0" encoding="UTF-8"?>
2 <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
3 xmlns="http://java.sun.com/xml/ns/javaee"
4 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
5 id="WebApp_ID" version="2.5">
6
7 <!-- 配置DispatchcerServlet -->
8 <servlet>
9 <servlet-name>springDispatcherServlet</servlet-name>
10 <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
11 <!-- 配置Spring mvc下的配置檔案的位置和名稱 -->
12 <init-param>
13 <param-name>contextConfigLocation</param-name>
14 <param-value>classpath:springmvc.xml</param-value>
15 </init-param>
16 <load-on-startup>1</load-on-startup>
17 </servlet>
18
19 <servlet-mapping>
20 <servlet-name>springDispatcherServlet</servlet-name>
21 <url-pattern>/</url-pattern>
22 </servlet-mapping>
23
24 </web-app>
注意:1. line12-15用於配置spring mvc的配置檔案的位置和名稱,這裡說明會新建一個springmvc.xml的配置檔案
2. 我們也可以不新建springmvc.xml,而是用預設的,預設的配置檔案格式為/WEB-INF/[servlet-name]-servlet.xml,對應這裡的就是springDispatcherServlet-servlet.xml
3. 這裡的servlet-mapping表示攔截的模式,這裡是“/”,表示對於所有的請求的攔截,包括靜態資源如html, js, jpg等。這時候對於靜態資源的訪問就會報404的錯誤。關於如何解決後面會介紹
Springmvc.xml(scr下)
在src目錄下新建springmvc.xml
1 <?xml version="1.0" encoding="UTF-8"?>
2 <beans xmlns="http://www.springframework.org/schema/beans"
3 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4 xmlns:context="http://www.springframework.org/schema/context"
5 xmlns:mvc="http://www.springframework.org/schema/mvc"
6 xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
7 http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
8 http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
9
10
11 <!-- 配置自動掃描的包 -->
12 <context:component-scan base-package="com.jackie.springmvc"></context:component-scan>
13
14 <!-- 配置檢視解析器 如何把handler 方法返回值解析為實際的物理檢視 -->
15 <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
16 <property name = "prefix" value="/WEB-INF/views/"></property>
17 <property name = "suffix" value = ".jsp"></property>
18 </bean>
19 </beans>
注意:1. line12表示spring監聽的範圍,這裡是在com.jackie.springmvc下
2. line15-18,是添加了一個檢視解析器,用於把在控制器中handler的結構解析為實際的物理檢視,這個要配合controller類來解析,詳見下面。
HelloWorld.java(com.jackie.springmvc.handlers下)
1 package com.jackie.springmvc.handlers;
2
3 import org.springframework.stereotype.Controller;
4 import org.springframework.web.bind.annotation.RequestMapping;
5
6 @Controller
7 public class HelloWorld {
8
9 /**
10 * 1. 使用RequestMapping註解來對映請求的URL
11 * 2. 返回值會通過檢視解析器解析為實際的物理檢視, 對於InternalResourceViewResolver檢視解析器,會做如下解析
12 * 通過prefix+returnVal+suffix 這樣的方式得到實際的物理檢視,然後會轉發操作
13 * "/WEB-INF/views/success.jsp"
14 * @return
15 */
16 @RequestMapping("/helloworld")
17 public String hello(){
18 System.out.println("hello world");
19 return "result";
20 }
21 }
注意:1. 首先要在類的前面新增“Controller”註解,表示是spring的控制器,這裡會寫一個方法hello()
2. hello方法上方有一個@RequestMapping, 是用於匹配請求的路徑,比如這裡匹配的請求路徑就是“http://localhost:8080/springTest/springmvc/helloworld”,即當tomcat服務啟動後,在瀏覽器輸入這個url時,如果在這個方法打斷點了,就會跳入該方法。
3. 這個return的結果不是亂寫的,這個返回的字串就是與上面springmvc.xml中line15-18進行配合的,springmvc.xml中聲明瞭prefix和suffix,而夾在這兩者之間的就是這裡返回的字串,所以執行完這個方法後,我們可以得到這樣的請求資源路徑“/WEB-INF/views/success.jsp”,這個success.jsp是需要我們新建的
index.jsp(WebContent下)
在新建success.jsp之前,我們需要有一個入口,也就是這裡的index.jsp
1 <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
2 pageEncoding="ISO-8859-1"%>
3 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
4 <html>
5 <head>
6 <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
7 <title>Insert title here</title>
8 </head>
9 <body>
10
11 <a href="helloworld">hello world</a>
12
13 </body>
14 </html>
當訪問index.jsp時,頁面上會展示一個超連結,點選超鏈後,url中的地址就會發生跳轉,由“http://localhost:8080/springTest/index.jsp”跳轉到“http://localhost:8080/springTest/helloworld”,而這個url請求就會進入HelloWorld中的hello方法,因為其與該方法上的“/helloworld”匹配。
success.jsp(WEB-INF/views下)
該頁面是作為請求成功後的相應頁面
success.jsp至此,我們完成了基於Spring mvc框架的HelloWorld程式的開發,包括要依賴的jar包,配置的檔案,控制器程式碼的編寫和展示頁面的編寫等。
除此以外,再介紹下整個配置過程中遇到的一些小問題:
1. tomcat伺服器的新增
從前面的介紹可以看出,我們的程式是通過瀏覽器發請求來獲取想要的頁面,那麼這裡就免不了要有一個web伺服器,這裡就是tomcat。
首先你需要下載個tomcat,然後在eclipse->windows->preference->servers中繫結這個tomcat伺服器;
其次你需要在你新建的spring mvc專案中新增tomcat的支援,否則在新建的jsp檔案中會提示報錯“The superclass javax.servlet.http.HttpServlet was not found on the Java Build Path”
右鍵專案->build path->configure build path->add library->server runtime, 選擇你的tomcat即可
有了tomcat伺服器,你就可以在index.jsp上右鍵run on server,選擇你的tomcat伺服器,這樣就可以啟動tomcat服務,幫助你完成網頁的請求和響應操作。
2. spring mvc如何訪問靜態資源
關於使用spring mvc處理靜態資源,比如html(發現之前的springmvc.xml中<property name = "suffix" value = ".jsp"></property>定義為jsp結尾就可以成功跳轉,但是如果改為html並在web-inf下面新建了html檔案後,並將suffix這裡的".jsp"改為".html",無法跳轉到想要的html頁面,並且給出404錯誤,同時console給出錯誤資訊為:No mapping found for HTTP request with URI [/springTest/WEB-INF/views/result.html] in DispatcherServ)
最後發現是需要讓spring明確要處理靜態資源,原來的web.xml中只有
1 <servlet-mapping>
2 <servlet-name>springDispatcherServlet</servlet-name>
3 <url-pattern>/</url-pattern>
4 </servlet-mapping>
其匹配的都是controller中類似@RequestMapping("/springmvc/helloworld")這樣的註解配置的請求,而對於類似html/css/jpg等資源的訪問就會得不到,所以需要在web.xml中加入以下型別的支援
1 <servlet-mapping>
2 <servlet-name>default</servlet-name>
3 <url-pattern>*.css</url-pattern>
4 </servlet-mapping>
5
6 <servlet-mapping>
7 <servlet-name>default</servlet-name>
8 <url-pattern>*.gif</url-pattern>
9 </servlet-mapping>
10
11 <servlet-mapping>
12 <servlet-name>default</servlet-name>
13 <url-pattern>*.jpg</url-pattern>
14 </servlet-mapping>
15
16 <servlet-mapping>
17 <servlet-name>default</servlet-name>
18 <url-pattern>*.js</url-pattern>
19 </servlet-mapping>
20
21 <servlet-mapping>
22 <servlet-name>default</servlet-name>
23 <url-pattern>*.html</url-pattern>
24 </servlet-mapping>
這樣就可以保證spring 能夠攔截並處理靜態資源
這裡將HelloWorld.java中的hello方法改為:
@RequestMapping("/helloworld")
public String hello(){
System.out.println("hello world");
return "Jackie";
}
Springmvc.xml改為:
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value="/WEB-INF/views/"></property>
<property name = "suffix" value = ".jpg"></property>
</bean>
表示我們可以訪問jpg靜態圖片資源了
相關推薦
學習SpringMVC——從HelloWorld開始,簡單快速上手springmvc
1 <?xml version="1.0" encoding="UTF-8"?> 2 <beans xmlns="http://www.springframework.org/schema/beans" 3 xmlns:xsi="http://www.w3.org/2001
學習SpringMVC——從HelloWorld開始
前言: 雖然從學java的第一個程式——helloworld至今,已經有好幾個年頭了。當時自己找資料,看視訊,學習了java的輸入輸出流,多執行緒,網路程式設計等等, 而三大框架(Struts、Hi
從HelloWorld開始學習.NET Core
自動 info 我們 tabs tps 打包 set 依賴 HR 1.首先創建一個項目文件夾,如E:\CoreProjects 使用cmd命令進入到新建的文件夾中 2.創建一個HelloWorld項目 命令:dotnet new console -o hellow
Service Fabric學習-從helloworld開始
visual pub 圖標 增加節點 cto 異步 剛才 程序 sof 原先做服務器程序, 都是部署在xx雲上, 也沒理解雲是個啥, 不就是個服務器(虛擬機)租賃商嗎? 好吧, 其實這個是IaaS, 而接下來要學習的ServiceFabric(以下簡稱SF)是PaaS.
MSIL學習------從HelloWorld開始
tsp 關於 托管 tom -a compile tput 知識點 解析 1.有沒有必要學習IL 前段時間突然想搞搞IL語言,於是在博客園中找到了包建強前輩關於IL的文章學習,並且在包前輩博客裏看到了09年他與趙劼前輩關於是否有必要學習IL語言的爭論,作為一個剛入此行業
學習Scala:從HelloWorld開始
Classfile /D:/Workspace/scala/scala-test/HelloWorld/HelloWorld$.class Last modified 2014-4-1; size 596 bytes MD5 checksum 7b3e40952539579da28edc84f370a
事務的學習,從jdbc開始:jdbc對事務的支持與實現
如何實現 ransac 阻止 事務隔離 完成後 value 事務提交 val ack 在使用spring對項目進行開發時,所有的事務都是由spring來管理的。這樣一來我們就可以不需要操心事務,可以專心的處理業務代碼。 但是,事務的底層究竟是如何實現的呢?那就從j
##node從HelloWorld開始
cti response asc ava es5 OS end listen class 創建文件server.js //es5 var http = require(‘http‘); http.createServer(function (request, respo
C#:一切從HelloWorld開始
我的第一個C#程式:HelloWorld 1 using System; //using關鍵字用於在程式中包含 System 名稱空間。 一個程式一般有多個 using 語句。 2 namespace HelloWorld //namespace 宣告。一個 namespace
學習筆記:從0開始學習大資料-20. 機器學習spark ml演算法庫應用練習
作為大資料初學者,機器學習演算法的運用,只是hello world知道個123,以後專案需要再深入 Mahout,spark MLlib,spark ML三個演算法庫,根據網上了解比較,採用spark ml演算法庫作為學習物件。 本次學習只是除錯能執行網上的例子 程式碼案例網址: h
學習筆記:從0開始學習大資料-19. storm開發及執行環境部署
一.eclipse strom開發環境 1. eclipse waven開發環境支援storm java程式開發很簡單,只要pom.xml 加入依賴即可 <dependency> <groupId>org.apache.storm</
學習筆記:從0開始學習大資料-18.kettle安裝使用
Kettle是一款國外開源的ETL工具,純java編寫,可以在Windows、Linux、Unix上執行,資料抽取高效穩定。 Kettle 中文名稱叫水壺,該專案的主程式設計師MATT 希望把各種資料放到一個壺裡,然後以一種指定的格式流出。 Kettle這個ETL工具集,它允許你管理來自不同資料庫的
學習筆記:從0開始學習大資料-17.Redis安裝及使用
Redis 是一個高效能的key-value資料庫。 redis的出現,很大程度補償了memcached這類key/value儲存的不足,在部 分場合可以對關係資料庫起到很好的補充作用。 1. 下載 wget http://download.redis.io/releases/redis-5
學習筆記:從0開始學習大資料-16. kafka安裝及使用
kafka是訊息處理服務的開源軟體,高效高可用。可以作為大資料收集的工具或資料的管道。 1. 下載 http://kafka.apache.org/downloads 根據scala版本,我下載的是Scala 2.12 - kafka_2.12-2.1.0.tgz (as
學習筆記:從0開始學習大資料-15. Flume安裝及使用
上節測試了spark 程式設計,spark sql ,spark streaming 等都測試可用了,接下來是資料來源的收集,Flume的安裝使用,其實很簡單,但作為完整,也寫個記錄筆記 1.下載 wget http://archive.cloudera.com/cd
學習筆記:從0開始學習大資料-14. java spark程式設計實踐
上節搭建好了eclipse spark程式設計環境 在測試執行scala 或java 編寫spark程式 ,在eclipse平臺都可以執行,但打包匯出jar,提交 spark-submit執行,都不能執行,最後確定是版本問題,就是你在eclipse除錯的spark版本需和spark-submit
學習筆記:從0開始學習大資料-13. Eclipse+Scala+Maven Spark開發環境配置
上節配置好了spark執行環境,可以通過 spark-shell 在scala語言介面互動執行spark命令 可以參照( https://blog.csdn.net/u010285974/article/details/81840413 Spark-shell執行計算)
學習筆記:從0開始學習大資料-12. spark安裝部署
為了教學方便,考慮ALL IN ONE,一臺虛擬機器構建整個實訓環境,因此是偽分散式搭建spark 環境: hadoop2.6.0-cdh5.15.1 jdk1.8 centos7 64位 1. 安裝scala環境 版本是scala-2.12.7,官網下載
學習筆記:從0開始學習大資料-11. sqoop安裝部署
環境:centos7 已安裝java和hadoop 1.下載 wget http://archive.cloudera.com/cdh5/cdh/5/sqoop2-1.99.5-cdh5.16.0.tar.gz 2.解壓 tar -zxvf sqoop2-1.99.5-cdh5.16.0.t
學習筆記:從0開始學習大資料-10. hive安裝部署
1. 下載 wget http://archive.cloudera.com/cdh5/cdh/5/hive-1.1.0-cdh5.15.1.tar.gz 2.解壓 tar -zxvf hive-1.1.0-cdh5.15.1.tar.gz 3. hive的元資料(如表名,列