揭秘WCF REST架構(gòu)背后隱含概念
WCF經(jīng)過長時間的發(fā)展,很多用戶都很了解WCF REST架構(gòu)了,這里我發(fā)表一下個人理解,和大家討論討論。不同的人似乎對REST有不同的定義,有些定義是非常嚴(yán)格的,而有些則是比較自由的。我傾向于認(rèn)為WCF REST架構(gòu)存在于一個連續(xù)的范圍里, 如圖所示:
我們可以認(rèn)為WCF REST架構(gòu)背后隱含的基本理念如下:
◆越簡單越好
◆Web一直是非常成功的。
◆Web是很簡單的。
◆Web設(shè)計(jì)要遵循一些指導(dǎo)性原則,而這些原則在過去很長一段時間內(nèi)都是可靠的。
◆Web 服務(wù)的設(shè)計(jì)要以 Web的方式。
#T#不同的人對 REST有不同的定義,但可以肯定的是存在一些特征來影響一個服務(wù)是否是RESTful的,或者它能不能被認(rèn)為是RESTful, 或者它能否落在上面這個連續(xù)范圍內(nèi)的某個位置。這里列出一些(并不是全部)特征:
◆對HTTP 方法(GET,PUT,POST,DELETE是主要的HTTP方法)的合理使用——HI-REST端傾向于對具體方法用于具體的情景進(jìn)行嚴(yán)格的規(guī)定。例如一個HI-REST的實(shí)現(xiàn)中使用GET方法獲取,DELETE方法用來刪除,PUT方法用來插入或者更新,而POST方法則用來附加。而LO-REST 的解決方案則可能使用POST方法做插入,更新,刪除和附加操作。
◆對數(shù)據(jù)表現(xiàn)形式的選擇——HI-REST解決方案傾向于選擇標(biāo)準(zhǔn)的數(shù)據(jù)表現(xiàn)形式,而一些LO-REST解決方案則認(rèn)為POX也是一個不錯的選擇。
◆對良好構(gòu)造的URI的使用——HI-REST解決方案傾向于使用描述性的URI而一般情況下不使用查詢字符串,而我們在一些LO-REST解決方案中可以看到對查詢字符串的使用。
◆其他:有效負(fù)荷中包含指向相關(guān)信息的鏈接,使用合適的HTTP 響應(yīng)代碼。
我沒有在什么是REST的基礎(chǔ)上給出一個嚴(yán)格的定義,原因并不是我覺得這不重要。原因是,從WCF的角度,一個專門的定義無關(guān)緊要。WCF支持范圍兩端的 REST架構(gòu)(HI-REST和LO-REST)。事實(shí)上,在下一篇文章中,我將建立一個LO-REST的實(shí)現(xiàn),同時在之后的文章中,我將演示HI- REST端的實(shí)現(xiàn)。