鍍金池/ 問答/Java  PHP  C  Linux/ 為什么HTTP接口可以用COOKIE,那為什么需要設(shè)計成無狀態(tài)的?

為什么HTTP接口可以用COOKIE,那為什么需要設(shè)計成無狀態(tài)的?

寫接口的時候,HTTP請求命名可以設(shè)置COOKIE,將cookie帶到服務端,為什么接口需要設(shè)計成無狀態(tài)的,有什么好處?

回答
編輯回答
執(zhí)念

CookieHttp協(xié)議的補充部分,主要是為了解決標記用戶狀態(tài)的問題(比如登錄狀態(tài),通常用于MVC程序中),但HTTP接口通常應設(shè)計成無狀態(tài)的,以方便擴展,所以不應該使用Cookie,沒有必要也不安全。

2017年6月5日 05:14
編輯回答
旖襯

cookie不安全,如果接口攜帶cookie,那么抓包就可以拿到,拿到cookie的人,就可以隨便任意訪問接口了

2017年2月21日 21:19
編輯回答
初心

“無狀態(tài)”指是 HTTP 協(xié)議,它是一個請求,一個響應,就結(jié)束了。而多個請求之間是否存在關(guān)系,這是你利用 HTTP 實現(xiàn)你的業(yè)務邏輯的事,是否有狀態(tài),也是你自己怎么實現(xiàn)的事。絕大部分在這個層面都不是“無狀態(tài)”的。

更多地,你自己去了解一些其它的非 HTTP 的應用層協(xié)議,自然就明白了。

2018年5月7日 00:34
編輯回答
笑浮塵

你首先要知道 Cookie 是怎樣產(chǎn)生的, 如我們第一次通過瀏覽器訪問一個web服務,在服務端會產(chǎn)生一個會話信息 Session, 該服務器響應你的請求時會將該會話信息的 session_id 以 cookie 寫入到你的瀏覽器,下次訪問時,會帶著這個cookie信息進行會話驗證;
而 APP 的接口是沒有通過瀏覽器訪問的,所以也就在服務器端不會生成session,在客戶端也不會寫入cookie,那么也就拿不到會話信息,所以,為了能夠像瀏覽器那樣記住同一客戶的信息,Token就誕生了, 用戶每次訪問服務端時,會帶著這個Token,而服務端通過這個Token拿到用戶的相關(guān)信息,然后再處理。

2017年12月5日 08:47
編輯回答
悶騷型

因為 接口可以在其他地方使用,不只是瀏覽器 比如 手機app端,那樣的話就無法保證他的狀態(tài)了(但現(xiàn)在大部分app有封裝支持cookie的),所以說通信的時候要帶一個token來做用戶認證。?

2018年3月11日 17:04
編輯回答
我以為

大部分http請求都是不需要保存用戶狀態(tài)的,比如我們?yōu)g覽web頁面,大多數(shù)時候你也不會想要去登錄。但也有很多情況我們需要保存用戶狀態(tài)。所以Cookie和Session誕生了!

2018年4月24日 10:25
編輯回答
淡墨

我覺得吧,api的安全性更重要些。
瀏覽器的cookie可以自動處理一些東西,比如關(guān)了瀏覽器會話cookie就過期,可以從一定程度上確保會話的安全性。但是api請求的話你不知道他啥時候會“關(guān)瀏覽器”,而且涉及到一些金額變更什么的接口,如果一直用cookie的話可能會存在安全隱患。api可以設(shè)計成每次都帶上不同的token,即使是同個接口同樣參數(shù),也是可以加上時間參數(shù)確保同樣的token不能無限使用的。

2017年3月19日 07:36
編輯回答
尋仙

我覺得的吧,這個是需要看具體的應用場景的。(無狀態(tài)api=>restful)

引用知乎上某大神的說法,restful使用場景是Machine-to-machine的系統(tǒng)集成,目標是讓服務發(fā)布者和消費者在最小約束下自由演化。
這個約束是指服務契約,簡單講就是服務輸入輸出的語義。消費者只需知道服務的根資源的URI,就可以由根資源引導到所需的資源。換句話說,消費者和發(fā)布者的耦合只在于根資源的URI以及各資源及其操作的語義。這樣做的好處如下:
1.服務自解釋
2.降低服務的版本粒度
3.降低消費者對服務內(nèi)部實現(xiàn)細節(jié)的耦合,不需要考慮上下文,以及當前狀態(tài),極大的降低了耦合。
4.restful基于http,本身提供了豐富的內(nèi)容協(xié)商手段,無論是緩存,還是資源修改的樂觀并發(fā)控制。都可以以業(yè)務無關(guān)的中間件來實現(xiàn)。

而采用cookie,則是為了記錄某種狀態(tài),用來實現(xiàn)上下文貫通,記錄訪問者狀態(tài)的手段。保存在客戶端的cookie確實容易被盜取,但是通過一些加密等安全手段也是可以增強安全性。

2017年7月27日 14:46
編輯回答
維他命

節(jié)約資源吧,css也是http請求,記住css的狀態(tài)不是有點浪費

2017年8月30日 10:55