日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

APP 请求验证

發布時間:2025/4/16 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 APP 请求验证 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

http://blog.ubooksapp.com/

前一段時間,在刷博客的時候發現一個挺有意思的應用(美團圖書館),突然覺得自己還真有些這方面的需求,所以打算復制一個app出來跟身邊的同學們一起玩玩,自覺該會是一件蠻有意思的事,哈哈。

開始想法比較簡單,首先搭建restful web services, 已經構想出來的REST API并不多, 如:

POST ../api-v1/user/loginPOST ../api-v1/user/registerPOST ../api-v1/books/shareGET ../api-v1/booksGET ../api-v1/user/12345

給人的感覺相當舒服,API 設計參考 Learn REST: A RESTful Tutorial, API的實現采用了Phalcon, 這是一個采用C語言擴展編寫,針對高性能優化的PHP5框架。

Authenticating REST Requests

一般 REST 請求不允許匿名,每次請求都需要攜帶身份驗證信息,通過系統驗證后才能成功請求。

在用戶成功登錄系統后,客戶端會保存一個Secret Access Key,這個Access Key由服務器生成,和客戶端共享,是一個用戶身份標識,通常可以是User ID。

當客戶端發起請求時,先生成signature,然后將Access Key 和 signature添加到請求的頭部信息中去,再發送至服務器。signature由多個頭部信息連接后通過加密得到,例如:

base64(hmac-sha1(VERB + "\n" + CONTENT-MD5 + "\n" + CONTENT-TYPE + "\n" + DATE + "\n" + CanonicalizedSelfHeaders + "\n" + CanonicalizedResource))

得到請求頭部類似:

PUT /quotes/nelson HTTP/1.0 Authorization: AWS 44CF9590006BF252F707:jZNOcbfWmD/A/f3hSvVzXZjM2HU= Content-Md5: c8fdb181845a4ca6b8fec737b3581d76 Content-Type: text/html Date: Thu, 17 Nov 2005 18:49:58 GMT X-Amz-Meta-Author: foo@bar.com X-Amz-Magic: abracadabra

服務器接收到請求,對signature進行驗證比較,即使用與客戶端相同的加密方法生成一個signature與接收到的signature進行比較,如果相同,則身份認證通過,否則,返回錯誤信息。

AWS Authenticating REST Requests
REST API Login Pattern


總結

以上是生活随笔為你收集整理的APP 请求验证的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。