国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Spring mvc Controller和RestFul原理解析

瀏覽:16日期:2023-09-15 18:58:47

控制器Controller

控制器復雜提供訪問應用程序的行為,通常通過接口定義或注解定義兩種方法實現(xiàn)。 控制器負責解析用戶的請求并將其轉(zhuǎn)換為一個模型。 在Spring MVC中一個控制器類可以包含多個方法 在Spring MVC中,對于Controller的配置方式有很多種

實現(xiàn)Controller接口

Controller是一個接口,在org.springframework.web.servlet.mvc包下,接口中只有一個方法;

//實現(xiàn)該接口的類獲得控制器功能public interface Controller { //處理請求且返回一個模型與視圖對象 ModelAndView handleRequest(HttpServletRequest var1, HttpServletResponse var2) throws Exception;}

測試

編寫一個Controller類,ControllerTest1

// 定義控制器// 注意點:不要導錯包,實現(xiàn)Controller接口,重寫方法;public class ControllerTest1 implements Controller { public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception { //返回一個模型視圖對象 ModelAndView mv = new ModelAndView(); mv.addObject('msg','Test1Controller'); mv.setViewName('test'); return mv; }}

編寫完畢后,去Spring配置文件中注冊請求的bean;name對應請求路徑,class對應處理請求的類

<bean name='/t1' />

編寫前端test.jsp,注意在WEB-INF/jsp目錄下編寫,對應我們的視圖解析器

<%@ page contentType='text/html;charset=UTF-8' language='java' %><html><head> <title>Kuangshen</title></head><body> ${msg}</body></html>

配置Tomcat運行測試,我這里沒有項目發(fā)布名配置的就是一個 / ,所以請求不用加項目名,OK!

說明:

實現(xiàn)接口Controller定義控制器是較老的辦法

缺點是:一個控制器中只有一個方法,如果要多個方法則需要定義多個Controller;定義的方式比較麻煩;

使用注解@Controller

@Controller注解類型用于聲明Spring類的實例是一個控制器(在講IOC時還提到了另外3個注解);

Spring可以使用掃描機制來找到應用程序中所有基于注解的控制器類,為了保證Spring能找到你的控制器,需要在配置文件中聲明組件掃描。

<!-- 自動掃描指定的包,下面所有注解類交給IOC容器管理 --><context:component-scan base-package='com.xiaohua.controller'/>

增加一個ControllerTest2類,使用注解實現(xiàn);

// @Controller注解的類會自動添加到Spring上下文中@Controllerpublic class ControllerTest2{ //映射訪問路徑 @RequestMapping('/t2') public String index(Model model){ //Spring MVC會自動實例化一個Model對象用于向視圖中傳值 model.addAttribute('msg', 'ControllerTest2'); //返回視圖位置 return 'test'; }}

運行tomcat測試

可以發(fā)現(xiàn),我們的兩個請求都可以指向一個視圖,但是頁面結(jié)果的結(jié)果是不一樣的,從這里可以看出視圖是被復用的,而控制器與視圖之間是弱偶合關系。

RequestMapping@RequestMapping注解用于映射url到控制器類或一個特定的處理程序方法。可用于類或方法上。用于類上,表示類中的所有響應請求的方法都是以該地址作為父路徑。

為了測試結(jié)論更加準確,我們可以加上一個項目名測試 myweb

只注解在方法上面

@Controllerpublic class TestController { @RequestMapping('/h1') public String test(){ return 'test'; }}

訪問路徑:http://localhost:8080 / 項目名 / h1

同時注解類與方法

@Controller@RequestMapping('/admin')public class TestController { @RequestMapping('/h1') public String test(){ return 'test'; }}

訪問路徑:http://localhost:8080 / 項目名/ admin /h1 , 需要先指定類的路徑再指定方法的路徑;

RestFul風格Restful就是一個資源定位及資源操作的風格。不是標準也不是協(xié)議,只是一種風格。基于這個風格設計的軟件可以更簡潔,更有層次,更易于實現(xiàn)緩存等機制。

功能

資源:互聯(lián)網(wǎng)所有的事物都可以被抽象為資源 資源操作:使用POST、DELETE、PUT、GET,使用不同方法對資源進行操作。 分別對應 添加、 刪除、修改、查詢。

傳統(tǒng)方式操作資源 :通過不同的參數(shù)來實現(xiàn)不同的效果!方法單一,post 和 get

http://127.0.0.1/item/queryItem.action?id=1 查詢,GET http://127.0.0.1/item/saveItem.action 新增,POST http://127.0.0.1/item/updateItem.action 更新,POST http://127.0.0.1/item/deleteItem.action?id=1 刪除,GET或POST

使用RESTful操作資源 : 可以通過不同的請求方式來實現(xiàn)不同的效果!如下:請求地址一樣,但是功能可以不同!

http://127.0.0.1/item/1 查詢,GET http://127.0.0.1/item 新增,POST http://127.0.0.1/item 更新,PUT http://127.0.0.1/item/1 刪除,DELETE

學習測試

在新建一個類 RestFulController

@Controllerpublic class RestFulController {}

在Spring MVC中可以使用 @PathVariable 注解,讓方法參數(shù)的值對應綁定到一個URI模板變量上。

@Controllerpublic class RestFulController { //映射訪問路徑 @RequestMapping('/commit/{p1}/{p2}') public String index(@PathVariable int p1, @PathVariable int p2, Model model){ int result = p1+p2; //Spring MVC會自動實例化一個Model對象用于向視圖中傳值 model.addAttribute('msg', '結(jié)果:'+result); //返回視圖位置 return 'test'; }}

我們來測試請求查看下

使用路徑變量的好處?

使路徑變得更加簡潔; 獲得參數(shù)更加方便,框架會自動進行類型轉(zhuǎn)換。 通過路徑變量的類型可以約束訪問參數(shù),如果類型不一樣,則訪問不到對應的請求方法,如這里訪問是的路徑是/commit/1/a,則路徑與方法不匹配,而不會是參數(shù)轉(zhuǎn)換失敗。

我們來修改下對應的參數(shù)類型,再次測試

//映射訪問路徑@RequestMapping('/commit/{p1}/{p2}')public String index(@PathVariable int p1, @PathVariable String p2, Model model){ String result = p1+p2; //Spring MVC會自動實例化一個Model對象用于向視圖中傳值 model.addAttribute('msg', '結(jié)果:'+result); //返回視圖位置 return 'test';}

使用method屬性指定請求類型

用于約束請求的類型,可以收窄請求范圍。指定請求謂詞的類型如GET, POST, HEAD, OPTIONS, PUT, PATCH, DELETE, TRACE等

我們來測試一下:

增加一個方法

//映射訪問路徑,必須是POST請求@RequestMapping(value = '/hello',method = {RequestMethod.POST})public String index2(Model model){ model.addAttribute('msg', 'hello!'); return 'test';}

我們使用瀏覽器地址欄進行訪問默認是Get請求,會報錯405:

如果將POST修改為GET則正常了;

//映射訪問路徑,必須是Get請求@RequestMapping(value = '/hello',method = {RequestMethod.GET})public String index2(Model model){ model.addAttribute('msg', 'hello!'); return 'test';}

小結(jié):

Spring MVC 的 @RequestMapping 注解能夠處理 HTTP 請求的方法, 比如 GET, PUT, POST, DELETE 以及 PATCH。

所有的地址欄請求默認都會是 HTTP GET 類型的。

方法級別的注解變體有如下幾個: 組合注解

@GetMapping @PostMapping @PutMapping @DeleteMapping @PatchMapping @GetMapping 是一個組合注解

它所扮演的是 @RequestMapping(method =RequestMethod.GET) 的一個快捷方式。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標簽: Spring
相關文章:
主站蜘蛛池模板: 久久精品视频在线 | 欧美孕交视频 | 五月久久亚洲七七综合中文网 | 欧美性aaaxxx级| 毛片高清 | 一本色道久久爱88av | 久久国产成人 | 国产欧美精品一区二区三区 | 精品一区二区三区视频在线观看免 | 欧美做爰性欧美 | 97国产在线视频 | 欧美兽皇video| 久久亚洲国产中v天仙www | 欧美最黄视频 | 日本一级毛片视频无遮挡免费 | 精品视频一区二区 | 一本色道久久88综合亚洲精品高清 | 日本一线一区二区三区免费视频 | 国产香蕉成人综合精品视频 | 日韩毛片在线免费观看 | 看一级毛片 | a毛片免费全部在线播放毛 a毛片免费视频 | 欧美成人午夜视频免看 | 怡红院最新免费全部视频 | 一区二区三区四区产品乱码伦 | 九色视频在线观看免费 | 国产高清一级片 | 亚洲一区二区三区一品精 | 国产美女在线精品亚洲二区 | 国产精品18久久久久久久久久 | 久久久久久国产精品免费 | 精品欧美一区二区在线观看欧美熟 | 日产国产精品久久久久久 | 欧美亚洲综合网 | 91成人小视频| 欧美jizzhd精品欧美另类 | 国产精品自拍视频 | se94se欧美| 日韩一中文字幕 | 国产欧美一区二区精品性色 | 香港a毛片免费全部播放 |