大家好,我是IT修真院成都分院第九期學員楊以杰,一枚正直純潔善良的JAVA程序員
今天給大家分享一下,修真院官網JAVA任務2的深度思考:為什么要用REST風格以及不用的話接口怎么定義
PPT鏈接:PPT
為什么要用REST風格以及不用的話接口怎么定義_騰訊視頻
1.背景介紹
官方介紹:REST(Representational State Transfer)指的是一種架構設計風格,而滿足這種設計風格的應用程序或設計就被認為是RESTful架構風格。這也是目前互聯網中最流行的一種軟件架構風格,它結構清晰、符合標準、易于理解,越來越多的應用服務開始使用RESTful這種架構風格,尤其是那些基于HTTP協議的網絡服務。
2.知識剖析
REST -- REpresentational State Transfer 中文翻譯過來是:表現層狀態轉移。這個中文直譯經常出現在很多博客中。尼瑪誰聽得懂“表現層狀態轉移”?這是人話嗎?
之所以晦澀是因為前面主語被去掉了,全稱是 Resource Representational State Transfer:通俗來講就是:資源在網絡中以某種表現形式進行狀態轉移。分解開來:
Resource:資源,即數據它可以是一段文本、一張圖片、一首歌曲等;
Representational:某種表現形式,比如用JSON,XML,JPEG等;
State Transfer:狀態變化。通過HTTP動詞實現。
Rest風格總結后就是:
URL定位資源,用HTTP動詞(GET,POST,DELETE,PUT)描述操作。
1. REST描述的是在網絡中client和server的一種交互形式;REST本身不實用,實用的是如何設計 RESTful API(REST風格的網絡接口);
2. Server提供的RESTful API中,URL中只使用名詞來指定資源,原則上不使用動詞。“資源”是REST架構或者說整個網絡處理的核心。
3. 用HTTP協議里的動詞來實現資源的添加,修改,刪除等操作。
4. Server和Client之間傳遞某資源的一個表現形式,比如用JSON,XML傳輸文本,或者用JPG,WebP傳輸圖片等。當然還可以壓縮HTTP傳輸時的數據(on-wire data compression)。
5. 用 HTTP Status Code傳遞Server的狀態信息。比如最常用的 200 表示成功,500 表示Server內部錯誤等。
為什么要用RESTful結構呢?
近年來移動互聯網的發展,各種類型的Client層出不窮,RESTful可以通過一套統一的接口為 Web,iOS和Android提供服務。另外對于廣大平臺來說,比如Facebook ,微博開放平臺,微信公共平臺等,它們不需要有顯式的前端,只需要一套提供服務的接口,于是RESTful更是它們最好的選擇。
3.常見問題
舉例說明:
我想定義接口,一個是獲取信息,一個是刪除信息,一個修改信息,一個新增信息以下接口看起來是沒有問題的,而且大家一般也是這么做的
/user/getinfo
/user/putinfo?id=
/user/delinfo?id=
/user/add
但是,這不是RESTful的,因為你定義了一個行為,將行為細節都交給接口實現的,每一個行為獨占一個接口,如果業務有變更,你可能還要改,比如要求只能刪除7天之前的。以下接口則是RESTfull的,接口僅描述了資源,具體操作由指定的動作來完成。
4.解決方案
使用HTTP協議動詞來做增刪改查操作
GET /user/info
DEL /user/info?id=
PUT /user/info?id=
POST /user/info
這樣,服務端僅需要簡單的維護資源,做狀態切換卻可。對于只能刪除7天之前的這種事,則由上層邏輯去控制,底層安穩的一直存在下去,除非某一天,確實不用這個資源了。
5.擴展思考
為什么要用RESTful結構呢?
近年來移動互聯網的發展,各種類型的Client層出不窮,RESTful可以通過一套統一的接口為 Web,iOS和Android提供服務。,有了RESTful結構,不管是電腦端還是手機端,或者是APP,按照REST的接口來進行數據交互,完全不用關心后端實現,也就是說,前端和后端真正的實現了完全的分離設計。
提問環節:
①在jsp中并不支持使用put以及delete標簽,我們該怎么使用?
答:在form表單中增加一條隱藏屬性,
<input type="hidden" name="_method" value="DELETE">
②頁面重定向和轉發分別是什么?有什么區別
forward過程
轉發,服務器端行為。web服務器把接受的請求,調用內部的方法在容器內部完成請求處理和轉發動作,然后響應客戶端,在這里,轉發的路徑必須是同一個web容器下的url,其不能轉向到其他的web路徑上去,中間傳遞的是自己的容器內的request。
重定向,客戶端行為。客戶端發送http請求,web服務器接受后發送3**狀態碼響應及對應新的location給客客戶端,客戶端發現是3**響應,則自動再發送一個新的http請求,請求url是新的location地址,在這里location可以重定向到任意URL,既然是瀏覽器重新發出了請求,則就沒有什么request傳遞的概念了。重定向行為是瀏覽器做了至少兩次的訪問請求的。
forward:你先去A局辦事,A局看了以后,知道這個事情其實應該B局來管,但是他沒有把你退回來,而是讓你坐一會兒,自己到后面辦公室聯系了B的人,讓他們辦好后,送了過來。
redirect:你先去了A局,A局的人說:“這個事情不歸我們管,去B局”,然后,你就從A退了出來,自己乘車去了B局辦。
當然,這個比喻也不是很準確,理解表達的意思就行。
------------------------------------------------------------------------------------------------------------------------
今天的分享就到這里啦,歡迎大家點贊、轉發、留言、拍磚~
下期預告:nginx如何實現負載均衡?不見不散~
技能樹.IT修真院
“我們相信人人都可以成為一個工程師,現在開始,找個師兄,帶你入門,掌控自己學習的節奏,學習的路上不再迷茫”。
這里是技能樹.IT修真院,成千上萬的師兄在這里找到了自己的學習路線,學習透明化,成長可見化,師兄1對1免費指導。快來與我一起學習吧~
作者:萌新架構師