鸿 网 互 联 www.68idc.cn

当前位置 : 主页 > 编程语言开发 > java > >

SpringMVC常用注解實例詳解1:@Controller,@RequestMapping,@Req

来源:互联网 作者:佚名 时间:2013-11-29 09:55
我的開發環境 框架: springmvc+spring+freemarker 開發工具: springsource-tool-suite-2.9.0 JDK版本: 1.6.0_29 tomcat版本:apache-tomcat-7.0.26 前置文章-SpirngMVC配置入門 Spring整合Freemarker [email protected],@RequestMapping 用@Controller註釋的類

我的開發環境
框架:        springmvc+spring+freemarker
開發工具: springsource-tool-suite-2.9.0
JDK版本: 1.6.0_29
tomcat版本:apache-tomcat-7.0.26

前置文章-SpirngMVC配置入門 

             Spring整合Freemarker 

[email protected],@RequestMapping

用@Controller註釋的類才會被SpringMVC解析器搜索到,這個註釋是必須的。@RequestMapping註釋用於指定controller方法的URL索引。這兩個注解的具體用法請看以下代碼:

controller层LearnMVCController.java代码:

 

package ; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; @Controller @RequestMapping("/ LearnMVCController { @RequestMapping("/ String learnMVC() { return "learnMVC.ftl"; } }

视图learnMVC.ftl代码:

Insert title hereHello World!

 

有父索引的请况下,访问::8080/你的工程名/learnMVC/ex.htm

省略父索引的请况下,访问::8080/你的工程名/ex.htm 就可将请求发送到所需controller方法。

运行结果:

[email protected]

該註釋用於controller方法註釋中,用於綁定由視圖傳過來的參數,代碼如下:

controller代碼

package ; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; @Controller @RequestMapping("/learnMVC") public class LearnMVCController { @RequestMapping("/ex") public String learnMVC(@RequestParam(value = "userId", required = false) Integer userIdGot, Model model) { String str = "成功得到綁定數據:" + userIdGot; model.addAttribute("userIdGot", str); return "learnMVC.ftl"; } }

@RequestParam註釋參數中,控制器會掃描視圖傳遞過來的、參數名與value值相同的參數,此處為userId,掃描到參數后將參數的值綁定到註釋後面聲明的變量中,此處為userIdGot.

例如我們訪問地址::8080/你的工程名/learnMVC/ex.htm?userId=10001

那麼首先控制器掃描到URL鏈接後面帶的變量userId與value的值相同,所以控制器把變量userId的值10001賦給了@RequestParam後面聲明的變量userIdGot,這樣我們就得到了前臺傳過來的參數。

required參數為true的時候,如果你沒傳所需的參數,,程序將報錯。required參數可省略,省略時,其值默認為false.

注意:這個例子當中,如果聲明變量Integer userIdGot改成int userIdGot,而你又沒有傳相應的參數,訪問頁面將報錯。因為當控制器找不到匹配的變量時,會把null賦給這個變量,而null值裝化為int的時候會報錯,所以此處應用包裝類

編寫視圖文件如下:

Insert title here${userIdGot}

在瀏覽器訪問::8080/你的工程名/learnMVC/ex.htm?userId=10001

運行結果如下:

[email protected]

@PathVariable用於綁定URL路徑上添加的參數,例如本文的連接: 如果是我們訪問控制層的路徑的話,那麼/p/3421707就是我們添加的參數,通過@PathVariable就可以綁定獲取這些參數在服務端進行相應操作。詳細使用方法情況以下代碼:

首先編寫learnMVC.ftl,代碼如下:

Insert title here${msgGot}

編寫controller層,代碼如下:

package ; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; @Controller @RequestMapping("/learnMVC") public class LearnMVCController { //子索引由 ex+參數+參數 組成 @RequestMapping("/ex/{type}/{articleId}") public String learnMVC(@PathVariable(value = "type") String typeGot, @PathVariable(value = "articleId") Integer articleIdGot, Model model) { String str = "URL後面所傳輸的參數為:" + typeGot + "/" + articleIdGot; model.addAttribute("msgGot", str); return "learnMVC.ftl"; } }

@PathVariable的實現原理和@RequestParam相似,控制器掃描@RequestMapping路徑中、{}號裏面的參數名,把參數值綁定到[email protected]的value值相等的變量中,比如上例中,{type}的值被綁定到value="type"的註釋後面聲明的變量typeGot中,參數的個數可以自由設定,這裡為兩個參數。

注意:在訪問URL時,必須用ex/參數值/參數值 的格式才能訪問到上例中的controller方法,另外還要注意參數的類型。

現在讓我們運行工程,,在瀏覽器訪問::8080/你的工程名/learnMVC/ex/p/10086.htm    注:此處p對應{type},10086對應{articleId}

運行結果:

 

 complete!

网友评论
<