亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Spring MVC:基于注解的MVC(上)

2019-11-10 20:04:26
字體:
來源:轉載
供稿:網友

本文轉自:http://www.cnblogs.com/xrq730/p/5342650.html

什么是SPRing MVC

Spring MVC框架是一個MVC框架,通過實現Model-View-Controller模式來很好地將數據、業務與展現進行分離。從這樣一個角度來說,Spring MVC和Structs、Structs2非常類似。Spring MVC的設計是圍繞DispatcherServlet展開的,DispatcherServlet負責將請求派發到特定的handler。通過可配置的hander mappings、view resolution、locale以及theme resolution來處理請求并且轉到對應的視圖。Spring MVC請求處理的整體流程如圖:

Spring MVC有基于注解版與基礎.xml版的兩種用法,不過現在的企業級開發基本都使用的是注解版,沒別的原因,就是方便而已。因此后面的代碼示例,都是基于注解版本的,想了解基于.xml版本的Spring MVC的朋友可以自行上網查詢。

 

Spring MVC環境搭建

要開始本文后面的內容,自然要搭建一個Spring MVC的環境,那么首先建立一個java Web的工程,我建立的工程名字叫做SpringMVC,要搭建一個基礎功能的Spring MVC環境,必須引入的jar包是beans、context、core、expression、web、webmvc以及commons-logging。

然后,對web.xml添加一些內容:

<?xml version="1.0" encoding="UTF-8"?><web-app version="2.5"     xmlns="http://java.sun.com/xml/ns/javaee"     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee     http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">        <display-name></display-name>        <welcome-file-list>        <welcome-file>index.jsp</welcome-file>    </welcome-file-list>            <!-- 該監聽器將在Web容器啟動時激活Spring -->    <listener>        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>    </listener>        <!-- 處理由JavaBeans,Introspector的使用而引起的緩沖泄露,建議配置此監聽器 -->    <listener>        <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>    </listener>        <!--configure the setting of springmvcDispatcherServlet and configure the mapping-->    <servlet>        <servlet-name>springmvc</servlet-name>        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>        <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>     <servlet-mapping>        <servlet-name>springmvc</servlet-name>        <url-pattern>/</url-pattern>    </servlet-mapping></web-app>

兩個listener不是必須的,但是servlet是必須的,url-pattern用于開發者選擇哪些路徑是需要讓Spring MVC來處理的。接著在classpath下按照我們約定的名字springmvc-servlet.xml寫一個xml文件:

<?xml version="1.0" encoding="UTF-8"?><beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"       xmlns="http://www.springframework.org/schema/beans"      xmlns:mvc="http://www.springframework.org/schema/mvc"      xmlns:context="http://www.springframework.org/schema/context"      xmlns:aop="http://www.springframework.org/schema/aop"      xmlns:tx="http://www.springframework.org/schema/tx"      xsi:schemaLocation="http://www.springframework.org/schema/beans         http://www.springframework.org/schema/beans/spring-beans-4.2.xsd        http://www.springframework.org/schema/mvc        http://www.springframework.org/schema/mvc/spring-mvc-4.2.xsd        http://www.springframework.org/schema/context        http://www.springframework.org/schema/context/spring-context-4.2.xsd">            <context:annotation-config />        <context:component-scan base-package="com.xrq.controller"/>        <!-- 配置視圖解析器 -->    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">          <!-- WebRoot到一指定文件夾文件路徑 -->          <property name="prefix" value="/" />          <!-- 視圖名稱后綴  -->          <property name="suffix" value=".jsp" />      </bean>  </beans>

另外,由于使用了Spring,所以Tomcat啟動的時候默認會去WEB-INF下找applicationContext.xml,所以放一個空的applicationContext.xml到WEB-INF下:

復制代碼
<?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-4.2.xsd">    </beans>復制代碼

寫一個Java POJO,用于處理具體的請求:

復制代碼
@Controller@RequestMapping(value = "/test")public class TestController{    @RequestMapping    public String dispatchTest()    {        System.out.println("Enter TestController.dispatchTest");        return "test";    }}復制代碼

注意,這里有一個@Controller,這個注解和@Service注解意思差不多,都表示該類是一個Spring Bean,這樣就不需要再在Spring文件中為這個類定義Bean了。

另外,由于我前面在springmvc-servlet.xml中配置了prefix和suffix,因此return的時候就可以方便一些,不需要寫前綴和后綴,Spring MVC默認會轉發到(請求轉發是Spring MVC默認的頁面跳轉方式)"/test.jsp"路徑下。

最后別忘了,因為在web.xml中設置了啟動激活Spring,因此還需要寫一個applicationContext.xml(Spring文件的默認名字),當然,里面除了基本的聲明,什么實際內容都不需要。最終,WebRoot文件夾應該是這么一個結構:

最后,啟動容器,訪問"localhost:8080/SpringMVC/test",容器就會把該請求轉發到"localhost:8080/SpringMVC/test.jsp"頁面下了。

 

@RequestMapping注解

Spring MVC中最重要的注解應該就是@RequestMapping了,它是用于處理請求映射的。繼續看剛才的TestController:

復制代碼
@Controller@RequestMapping(value = "/test")public class TestController{    @RequestMapping    public String dispatchTest()    {        System.out.println("Enter TestController.dispatchTest()");        return "test";    }}復制代碼

類上的RequestMapping是用于第一層匹配的。"localhost:8080/SpringMVC/test"和"localhost:8080/SpringMVC/add",value是test,自然走的是前者。

接著看,比如我在TestController中又定義了三個方法,此時類上不使用RequestMapping注解:

復制代碼
@RequestMapping(value = "/add")public String dispatchAddTest(){    System.out.println("Enter TestControll.dispatchAddTest()");    return "test";}    @RequestMapping(value = "/add/add")public String dispatchAddAddTest(){    System.out.println("Enter TestControll.dispatchAddAddTest()");    return "test";}@RequestMapping(value = "/del")public String dispatchDelTest(){    System.out.println("Enter TestControll.dispatchDelTest()");    return "test";}復制代碼

那么這三個方法分別匹配的路徑是:

"localhost:8080/SpringMVC/add""localhost:8080/SpringMVC/add/add""localhost:8080/SpringMVC/del"

關于路徑匹配,再提一點,假如在類上和方法上都加了RequestMapping,那么將會以類路徑為基準,再向方法路徑做匹配,比如:

復制代碼
@Controller@RequestMapping(value = "/test/")public class TestController{    @RequestMapping(value = "common")    public String root()    {        System.out.println("Enter TestController.root()!");        return "result";    }}復制代碼

這種寫法,匹配的應當是:

"localhost:8080/SpringMVC/test/common""localhost:8080/SpringMVC/test/common/""localhost:8080/SpringMVC/test/common.html""localhost:8080/SpringMVC/test/common.jsp""localhost:8080/SpringMVC/test/common.vm"

類似這種的路徑,如果還想往"localhost:8080/SpringMVC/test/common/"再添加內容,那么root()這個方法就無法匹配到了,必須再添加方法。多說一句,"/"一直是一個容易弄混的東西,我自己試驗的時候發現,RequestMapping里面的value屬性,只要路徑不存在多級的關系,加不加"/"是沒有什么影響的。

另外,@RequestMapping還可以匹配請求類型,到底是GET還是POST還是其他的,這么做:

@RequestMapping(method = RequestMethod.POST)public String dispatchTest(){    System.out.println("Enter TestController.dispatchTest()");    return "test";}

這樣就指定了該方法只匹配"localhost:8080/SpringMVC/test"且請求方式為POST的請求。

前面頁面跳轉的方式都是轉發(dispatch)的方式,轉發在我看來未必是一種很好的方式,典型的就是處理表單的時候會有表單重復提交的問題,那么如何使用重定向(redirect)的方式進行頁面跳轉?可以這么寫Controller的方法,差別在于return部分:

@RequestMappingpublic String dispatchTest(Test test){    System.out.println("Enter TestController.dispatchTest(), test: " + test);    return "redirect:/test.jsp";}

最后,@RequestMapping中還有params、headers、consumes等幾個屬性,不過這幾個都不重要,也不常用,就不講了。

 

參數匹配

處理url也好、表單提交也好,參數匹配是非常重要的一個內容,萬幸,Spring MVC對參數請求的支持做得非常好----它會自動根據url或者表單中參數的名字和方法中同名形參進行匹配并賦值。

舉一個例子:

復制代碼
@Controller@RequestMapping(value = "/test")public class TestController{    @RequestMapping    public String dispatchTest(String testId, String ttestId)    {        System.out.println("Enter TestController.dispatchTest(), testId = " + testId +                 ", ttestId = " + ttestId);        return "test";    }}復制代碼

此時,我訪問"localhost:8080/SpringMVC/test?testId=1&ttestId=2",控制臺打印出:

Enter TestController.dispatchTest(), testId = 2, ttestId = 3

不僅如此,方法中還可以放入一個實體類對象:

復制代碼
public class Test{    private String tid;    private String nid;    private String bid;        public void setTid(String tid)    {        this.tid = tid;    }        public void setNid(String nid)    {        this.nid = nid;    }        public void setBid(String bid)    {        this.bid = bid;    }        public String toString()    {        return "tid = " + tid + ", nid = " + nid + ", bid = " + bid;    }}復制代碼

注意,實體類對象中如果私有屬性不打算對外提供,getter可以沒有,但是為了Spring MVC可以將對應的屬性根據屬性名稱進行匹配并賦值,setter必須要有。把TestController稍作改造,傳入一個對象:

@RequestMappingpublic String dispatchTest(Test test){    System.out.println("Enter TestController.dispatchTest(), test: " + test);    return "test";}

此時我訪問"http://localhost:8080/SpringMVC/test?tid=0&bid=1&nid=2",控制臺上打印出:

Enter TestController.dispatchTest(), test: tid = 0, nid = 2, bid = 1

看到,參數完全匹配。

不僅如此,再多試驗一點:

復制代碼
@RequestMappingpublic String dispatchTest(Test test1, Test test2, String tid, String nid){    System.out.println("Enter TestController.dispatchTest(), test1:" + test1 +             "; test2:" + test2 + "; tid:" + tid + "; nid:" + nid);    return "test";}復制代碼

訪問一樣地址"http://localhost:8080/SpringMVC/test?tid=0&bid=1&nid=2",結果是:

Enter TestController.dispatchTest(), test1:tid = 0, nid = 2, bid = 1; test2:tid = 0, nid = 2, bid = 1; tid:0; nid:2

結論就是:

假如方法的參數是普通的字符串,只要字符串名字有和請求參數中的key完全匹配的,Spring MVC就會將完全匹配的自動賦值假如方法的參數是實體類,只要實體類中的參數有和請求參數中的key完全匹配的,Spring MVC就會將完全匹配的自動賦值

對于url如此,應用到表單中也是一樣的,有興趣的可以自己試驗一下。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区二区久久久久久久| 日韩国产激情在线| 精品国产乱码久久久久久虫虫漫画| 97国产精品久久| 久久久天堂国产精品女人| 一本大道亚洲视频| 亚洲欧洲日韩国产| 亚洲女人初尝黑人巨大| 欧美激情区在线播放| 欧美激情伊人电影| 欧美大秀在线观看| 91免费看国产| 久久精品国产免费观看| 91国自产精品中文字幕亚洲| 国产精品入口尤物| 亚洲二区在线播放视频| 中文字幕欧美日韩va免费视频| 亚洲欧洲激情在线| 欧美一区二区三区艳史| 欧美激情亚洲另类| 国产91在线播放九色快色| 亚洲xxxx妇黄裸体| 国产精品天天狠天天看| 91国产精品视频在线| 中文日韩电影网站| 欧美激情久久久久| 日韩欧美在线播放| 亚洲黄色成人网| 日韩成人在线视频观看| 欧美日韩亚洲精品一区二区三区| 久久夜色精品国产亚洲aⅴ| 日韩成人激情影院| 国产精品十八以下禁看| 欧美国产日韩一区二区三区| 久久香蕉国产线看观看av| 国内久久久精品| 亚洲欧美一区二区三区在线| 欧美亚洲免费电影| 色妞在线综合亚洲欧美| 午夜精品久久17c| 亚洲国产另类久久精品| 国产91色在线播放| 国产精品三级久久久久久电影| 国产一区视频在线播放| 成人免费直播live| 亚洲人成五月天| 欧美大全免费观看电视剧大泉洋| 亚洲一区制服诱惑| 成人www视频在线观看| 国产精品福利无圣光在线一区| 欧美性生活大片免费观看网址| 国产大片精品免费永久看nba| 国产在线a不卡| 国产精品激情av电影在线观看| 欧美在线视频一二三| 久久琪琪电影院| 中文字幕日本欧美| 国产精品电影久久久久电影网| 日韩激情av在线免费观看| 久久伊人精品一区二区三区| 国产精品美女主播在线观看纯欲| 国产成人精品一区二区在线| 欧美理论电影网| 色视频www在线播放国产成人| www.亚洲天堂| 欧美日韩一区免费| 懂色av中文一区二区三区天美| 在线观看视频亚洲| 精品国产一区二区三区四区在线观看| 色av吧综合网| 在线观看国产成人av片| 8090成年在线看片午夜| 欧美电影在线播放| 久久精品最新地址| 欧美日韩国产色视频| 国产脚交av在线一区二区| 日本sm极度另类视频| 久久精视频免费在线久久完整在线看| www.日韩av.com| 欧美在线激情视频| 久久国产精品偷| 久久青草精品视频免费观看| 中文日韩电影网站| 欧美专区在线观看| 亚洲成av人片在线观看香蕉| 欧美视频在线观看 亚洲欧| 午夜精品久久久久久久99黑人| 国产成人一区二区在线| 最新69国产成人精品视频免费| 欧美国产一区二区三区| 成人中文字幕+乱码+中文字幕| 精品久久久香蕉免费精品视频| 色偷偷av一区二区三区乱| 中日韩午夜理伦电影免费| 国产97在线|日韩| 少妇高潮久久久久久潘金莲| 国产精选久久久久久| 国产精品va在线播放我和闺蜜| 1769国内精品视频在线播放| 国产乱肥老妇国产一区二| 视频一区视频二区国产精品| 中文字幕免费精品一区高清| 欧美亚洲另类制服自拍| 国产91精品久久久久| 日韩精品免费一线在线观看| 91亚洲国产精品| 91精品国产91久久久久久最新| 亚洲精品电影网| 色悠久久久久综合先锋影音下载| 欧美夫妻性视频| 俺也去精品视频在线观看| 国产精品第100页| 久久久精品国产| 久久香蕉国产线看观看av| 亚洲一区av在线播放| 亚洲人成啪啪网站| 欧洲精品在线视频| 国产精品久久久久久一区二区| 欧美日韩黄色大片| 福利微拍一区二区| 国产一区二区三区久久精品| 中文字幕日韩视频| 亚洲成人激情小说| 91爱爱小视频k| 成人精品视频99在线观看免费| 国产欧洲精品视频| 国产欧美日韩精品在线观看| 亚洲直播在线一区| 成人写真福利网| 国内外成人免费激情在线视频网站| 久久精品99久久香蕉国产色戒| 精品久久香蕉国产线看观看亚洲| 国产精品高潮呻吟久久av无限| 亚洲片av在线| 亚洲精品动漫久久久久| 亚洲二区在线播放视频| 欧美在线免费观看| 午夜精品一区二区三区在线视频| 亚洲精品美女在线观看播放| 欧美激情一级精品国产| 久久亚洲综合国产精品99麻豆精品福利| 国产精品老牛影院在线观看| 久久久国产精彩视频美女艺术照福利| 高跟丝袜欧美一区| 欧美国产日产韩国视频| 欧美在线亚洲在线| 成人黄色影片在线| 热re91久久精品国99热蜜臀| 庆余年2免费日韩剧观看大牛| 久久久精品一区二区三区| 亚洲精品一区在线观看香蕉| 久久久久久久爱| 亚洲系列中文字幕| 国产一区二区三区视频免费| 日韩激情av在线播放| 久久精彩免费视频| 国产精品黄视频| 日韩三级影视基地| 91精品中文在线| 日本成人激情视频| 91久久久久久久一区二区| 亚洲自拍偷拍视频| 日韩av电影手机在线观看| 欧美高清在线观看|