接口測試
分類:
serverAPI、httpAPI
B / S 和 C / S 的區別:(面試題)
CS 響應速度快,安全性強,用戶體驗好,一般應用於局域網中,但是開發維護成本高;
BS 可以實現跨平台,客戶端零維護,但是個性化能力低,響應速度較慢
http / https 的區別(面試題)
s ssl 協議
http://127.0.0.1:8080/jinrongcrm/login.jsp?name="admin"&pwd="123"
url 地址有哪些組成:
協議:http / https
端口號:http / https 80 / 443
請求方式:GET
參數:name、pwd
參數值:admin、123
域名部分
虛擬目錄部分
文件名
http 的請求有哪些:
GET、POST、HEAD、OPTIONS、PUT、DELETE、TRACE、CONNECT
GET:請求指定的頁面信息,並返回實體主體
HEAD:類似於 get 請求,只不過返回的響應中沒有具體的內容,用於獲取報頭
POST:向指定資源提交數據進行處理請求(例如提交表單或者上傳文件)。
數據被包含在請求體中。POST請求可能會導致新的資源的建立和/或已有資源的修改。
PUT:從客戶端向服務器傳送的數據取代指定的文檔的內容
DELETE:請求服務器刪除指定的頁面
CONNECT:HTTP / 1.1協議中預留給能夠將連接改為管道方式的代理服務器
OPTIONS:允許客戶端查看服務器的性能
TRACE:回顯服務器收到的請求,主要用於測試或診斷
GET 和 POST 的區別:(面試題)
1.GET:一般用於信息獲取,使用URL傳遞參數,對所發送信息的數量也有限制,一般在2000個字符
2.GET: 傳送的數據量較小,不能大於2KB。post 傳送的數據量較大,一般被默認為不受限制。但理論上,IIS4中最大量為80KB,IIS5中為100KB。 用IIS過濾器的只接受get參數,所以一般大型搜索引擎都是用get方式
3.GET:是從服務器上獲取數據,post 是向服務器傳送數據。 get 請求返回 request – URI 所指出的任意信息。
4.GET:是把參數數據隊列加到提交表單的ACTION屬性所指的URL中,值和表單內各個字段一一對應,在URL中可以看到。post是通過HTTP post機制,將表單內各個字段與其內容放置在HTML HEADER內一起傳送到ACTION屬性所指的URL地址,用戶看不到這個過程。
5.POST:一般用於修改服務器上的資源,對所發送的信息沒有限制。
6.GET方式需要使用Request.QueryString來取得變量的值,而POST方式通過Request.Form來獲取變量的值,也就是說Get是通過地址欄來傳值,而Post是通過提交表單來傳值。
request:
請求行( request line)、請求頭部( header )、空行和請求數據四個部分組成
response:
響應行、響應報頭、空行和響應正文
服務器的響應狀態碼:(面試題)
HTTP響應
服務器收到了客戶端發來的HTTP請求后,根據HTTP請求中的動作要求,服務端做出具體的動作,將結果回應給客戶端,稱為HTTP響應。
響應數據格式
HTTP響應由三部分組成:狀態行、響應頭、響應正文;
狀態行:包括協議版本Version、狀態碼Status Code、回應短語;
響應頭(server header):包括搭建服務器的軟件,發送響應的時間,回應數據的格式等信息,包含HTTP狀態碼 (HTTP Status Code) ;
響應正文:就是響應的具體數據。
HTTP狀態碼
HTTP狀態碼由三個十進制數字組成,第一個十進制數字定義了狀態碼的類型,后兩個數字有分類的作用。不同的狀態碼代表不同的含義。
HTTP狀態碼分類
共分為5種類型:
分類 | 分類描述 |
---|---|
1xx | 信息,服務器收到請求,需要請求者繼續執行操作 |
2xx | 成功,操作被成功接收並處理 |
3xx | 重定向,需要進一步的操作以完成請求 |
4xx | 客戶端錯誤,請求包含語法錯誤或無法完成請求 |
5xx | 服務器錯誤,服務器在處理請求的過程中發生了錯誤 |
HTTP狀態碼列表
狀態碼 | 狀態碼英文名稱 | 中文描述 |
---|---|---|
100 | Continue | 繼續。客戶端應繼續其請求 |
101 | Switching Protocols | 切換協議。服務器根據客戶端的請求切換協議。只能切換到更高級的協議,例如,切換到HTTP的新版本協議 |
200 | OK | 請求成功。一般用於GET與POST請求 |
201 | Created | 已創建。成功請求並創建了新的資源 |
202 | Accepted | 已接受。已經接受請求,但未處理完成 |
203 | Non-Authoritative Information | 非授權信息。請求成功。但返回的meta信息不在原始的服務器,而是一個副本 |
204 | No Content | 無內容。服務器成功處理,但未返回內容。在未更新網頁的情況下,可確保瀏覽器繼續顯示當前文檔 |
205 | Reset Content | 重置內容。服務器處理成功,用戶終端(例如:瀏覽器)應重置文檔視圖。可通過此返回碼清除瀏覽器的表單域 |
206 | Partial Content | 部分內容。服務器成功處理了部分GET請求 |
300 | Multiple Choices | 多種選擇。請求的資源可包括多個位置,相應可返回一個資源特征與地址的列表用於用戶終端(例如:瀏覽器)選擇 |
301 | Moved Permanently | 永久移動。請求的資源已被永久的移動到新URI,返回信息會包括新的URI,瀏覽器會自動定向到新URI。今后任何新的請求都應使用新的URI代替 |
302 | Found | 臨時移動。與301類似。但資源只是臨時被移動。客戶端應繼續使用原有URI |
303 | See Other | 查看其它地址。與301類似。使用GET和POST請求查看 |
304 | Not Modified | 未修改。所請求的資源未修改,服務器返回此狀態碼時,不會返回任何資源。客戶端通常會緩存訪問過的資源,通過提供一個頭信息指出客戶端希望只返回在指定日期之后修改的資源 |
305 | Use Proxy | 使用代理。所請求的資源必須通過代理訪問 |
306 | Unused | 已經被廢棄的HTTP狀態碼 |
307 | Temporary Redirect | 臨時重定向。與302類似。使用GET請求重定向 |
400 | Bad Request | 客戶端請求的語法錯誤,服務器無法理解 |
401 | Unauthorized | 請求要求用戶的身份認證 |
402 | Payment Required | 保留,將來使用 |
403 | Forbidden | 服務器理解請求客戶端的請求,但是拒絕執行此請求 |
404 | Not Found | 服務器無法根據客戶端的請求找到資源(網頁)。通過此代碼,網站設計人員可設置"您所請求的資源無法找到"的個性頁面 |
405 | Method Not Allowed | 客戶端請求中的方法被禁止 |
406 | Not Acceptable | 服務器無法根據客戶端請求的內容特性完成請求 |
407 | Proxy Authentication Required | 請求要求代理的身份認證,與401類似,但請求者應當使用代理進行授權 |
408 | Request Time-out | 服務器等待客戶端發送的請求時間過長,超時 |
409 | Conflict | 服務器完成客戶端的PUT請求是可能返回此代碼,服務器處理請求時發生了沖突 |
410 | Gone | 客戶端請求的資源已經不存在。410不同於404,如果資源以前有現在被永久刪除了可使用410代碼,網站設計人員可通過301代碼指定資源的新位置 |
411 | Length Required | 服務器無法處理客戶端發送的不帶Content-Length的請求信息 |
412 | Precondition Failed | 客戶端請求信息的先決條件錯誤 |
413 | Request Entity Too Large | 由於請求的實體過大,服務器無法處理,因此拒絕請求。為防止客戶端的連續請求,服務器可能會關閉連接。如果只是服務器暫時無法處理,則會包含一個Retry-After的響應信息 |
414 | Request-URI Too Large | 請求的URI過長(URI通常為網址),服務器無法處理 |
415 | Unsupported Media Type | 服務器無法處理請求附帶的媒體格式 |
416 | Requested range not satisfiable | 客戶端請求的范圍無效 |
417 | Expectation Failed | 服務器無法滿足Expect的請求頭信息 |
500 | Internal Server Error | 服務器內部錯誤,無法完成請求 |
501 | Not Implemented | 服務器不支持請求的功能,無法完成請求 |
502 | Bad Gateway | 作為網關或者代理工作的服務器嘗試執行請求時,從遠程服務器接收到了一個無效的響應 |
503 | Service Unavailable | 由於超載或系統維護,服務器暫時的無法處理客戶端的請求。延時的長度可包含在服務器的Retry-After頭信息中 |
504 | Gateway Time-out | 充當網關或代理的服務器,未及時從遠端服務器獲取請求 |
505 | HTTP Version not supported | 服務器不支持請求的HTTP協議的版本,無法完成處理 |