postman如何測試post請求參數為json類型

来源:http://www.cnblogs.com/gdsblog/archive/2017/06/27/7086781.html
-Advertisement-
Play Games

引言 Postman 是一個用來測試Web API的Chrome 外掛軟體,可由google store 免費取得並安裝於Chrome里,對於有在開發Web API的開發者相當有用,省掉不少寫測試頁面呼叫的工作,通常我們看到的使用情境多數是直接呼叫Web API而未隨著Request發送相關所需參數 ...


引言

    Postman 是一個用來測試Web API的Chrome 外掛軟體,可由google store 免費取得並安裝於Chrome里,對於有在開發Web API的開發者相當有用,省掉不少寫測試頁面呼叫的工作,通常我們看到的使用情境多數是直接呼叫Web API而未隨著Request發送相關所需參數,本篇就來說明如果我們想要在呼叫Web API時一併夾帶JSON數據時,該如何使用Postman?

   需求

  採用POST的請求方式,並且須夾帶JSON數據給Web API使用教程

   第一、設置URL

 

     第二、設置header中的Content-Type

  

    第三、設置Body

  

     第四、輸入json格式的測試數據

      

   小結

  在我們做前後端分離的項目的時候,這個工具測試後臺介面還是非常便利的,這博客希望幫助到大家。

 

 


 


WebAPI GET和POST請求的幾種方式

WebAPI GET和POST請求的幾種方式

GET請求

1.無參數get請求

 一般get請求有兩種寫法,一種是$.get()   一種是$.ajax({type:"get"}),我個人比較喜歡用後者。

下麵例子主要是get無參數請求,獲取人員列表並將數據返回到前臺,並將返回的json數據轉換成字元串彈出,以便知道是否請求成功,並且返回的數據是否正確

複製代碼 複製代碼
 1    $.ajax({
 2             url: "/api/Person/getList",
 3             type: "get",
 4             success: function (data) {
 5                 alert(JSON.stringify(data));
 6                 alert("成功");
 7             },
 8             error: function () {
 9                 alert("錯誤");
10             }
11         });
複製代碼 複製代碼

後臺代碼

複製代碼 複製代碼
 1  public class PersonController : ApiController
 2     {
 3       
 4         public List<Person> getList()
 5         {
 6             var PersonList = new List<Person>(){
 7                 new Person{Name="張和",Sex="男",Duty="工程師",CompanyName="北京XX科技有限公司"},
 8                 new Person{Name="張麗",Sex="女",Duty="工程師",CompanyName="北京XX科技有限公司"},
 9                 new Person{Name="張春雷",Sex="男",Duty="工程師",CompanyName="北京XX科技有限公司"}
10             };
11             return PersonList;
12         }
13     }
複製代碼 複製代碼

2.多個參數的Get請求,參數格式:data:{},例如 一個參數的get請求是data:{"Name":"張麗"},兩個參數:data:{"Name":"張麗","Sex":"女"},多個參數只是在{}裡加入多個參數而已。

複製代碼 複製代碼
 1   $.ajax({
 2             url: "/api/Person/GetPerson",
 3             type: "get",
 4             data:{"Name":"張麗","Sex":"女"},
 5             success: function (data) {
 6                 alert(data.Name+" "+data.Duty+"  "+data.CompanyName);
 7             },
 8             error: function () {
 9                 alert("錯誤");
10             }
11         });
複製代碼 複製代碼

後臺代碼

複製代碼 複製代碼
 1    public Person GetPerson(string Name,string Sex)
 2         {
 3             var PersonList = new List<Person>(){
 4                 new Person{Name="張和",Sex="男",Duty="工程師",CompanyName="北京XX科技有限公司"},
 5                 new Person{Name="張麗",Sex="女",Duty="工程師",CompanyName="北京XX科技有限公司"},
 6                 new Person{Name="張春雷",Sex="男",Duty="工程師",CompanyName="北京XX科技有限公司"}
 7             };
 8             var p = PersonList.FirstOrDefault(f => f.Name == Name&&f.Sex==Sex);
 9             return p;
10         }
複製代碼 複製代碼

最終效果

 

 

POST請求

1.無參數的POST請求

      無參數的POST請求和GET請求是一樣的,只不過是ajax里的type:"get"改成type:"post"而已,後臺函數要加 [HttpPost]標簽,主要是標記該函數是post請求函數,如果get請求是請求不進去該函數的。

2.一個參數的POST請求

    一個參數的post請求和GET請求的方式不一樣,後臺函數的參數必須用[FromBody]標記,這樣才能訪問到該函數,如果不加[FromBody] , ASP.NET Web API能夠正確的識別我們的UserController控制器處理Post /api/Person ,但卻不能找到一個可以接受的方法來處理請求。那麼有人就說了後臺參數加了[FromBody] ,js如下是不是就可以請求成功哪

 

複製代碼 複製代碼
 1  $.ajax({
 2             url: "/api/Person/Post_Person",
 3             type: "post",
 4             data:{"Name":"張麗"},
 5             success: function (data) {
 6                 alert("成功");
 7                 alert(data);
 8                 alert(data.Name + " "  + data.CompanyName);
 9             },
10             error: function () {
11                 alert("錯誤");
12             }
13         });
複製代碼 複製代碼

 

答案是失敗的,確切的說是可以訪問到PersonControler里的Post_Person方法的,但是Post_Person函數的參數是獲取不到前臺ajax傳遞過來的值得,為什麼呢?是因為Web API 要求請求傳遞的 [FromBody] 參數,是有一個特定的格式,才能被正確的獲取到。而這種特定的格式並不是我們常見的 key=value 的鍵值對形式。Web API 的模型綁定器希望找到 [FromBody] 里沒有鍵名的值,也就是說, 不是 key=value ,而是 =value 。

所以將data:{"Name":"張麗"}改成data:{"":"張麗"} 這樣後臺函數才可以正確接收到傳遞過來的參數值

3.多個參數的POST請求

   有人會認為多個參數的Post請求,就是後臺函數加多個帶[FromBody]標記的參數即可,如果你是這樣想的,那麼你錯了。請一定要記住多個參數POST請求,

[FromBody] 修飾的參數只能有一個 。我們需要對傳遞的多個參數進行封裝才行。   

 

 

複製代碼 複製代碼
 1 var Person = {
 2         Name: "張麗",
 3         Sex: "女",
 4         Duty: "ddd",
 5     }
 6     
 7         $.ajax({
 8             url: "/api/Person/Post_PersonObj",
 9             type: "post",
10             data: Person,
11             success: function (data) {
12                 alert("成功");
13                 alert(data);
14                 alert(data.Name + " " + data.CompanyName);
15             },
16             error: function (data) {
17                 alert(data.responseText);
18             }
19         });
複製代碼 複製代碼

 

後臺代碼 

複製代碼 複製代碼
 1 [HttpPost]
 2        public Person Post_PersonObj([FromBody]Person per)
 3         {
 4             var PersonList = new List<Person>(){
 5                 new Person{Name="張和",Sex="男",Duty="工程師",CompanyName="北京XX科技有限公司"},
 6                 new Person{Name="張麗",Sex="女",Duty="工程師",CompanyName="北京XX科技有限公司"},
 7                 new Person{Name="張春雷",Sex="男",Duty="工程師",CompanyName="北京XX科技有限公司"}
 8             };
 9             var p = PersonList.FirstOrDefault(f => f.Name == per.Name&&f.Sex==per.Sex);
10             return p;
11         }




整個例子的源代碼下載地址:http://pan.baidu.com/s/1mgooA8K

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 對於游戲玩家來說,對顯卡的關註度要高於電腦其它硬體,一般來說,顯卡越好,游戲性能往往越強。不過要持續發揮顯卡的最佳游戲性能,經常更新顯卡驅動也是很有必要的。那麼筆記本顯卡驅動怎麼更新?下麵小編以自己的Win10筆記本為例,教大家如何升級筆記本顯卡驅動。 Win10筆記本顯卡驅動更新升級方法 升級筆記 ...
  • 1.下載最新的openssh包 http://www.openssh.com/portable.html#http 2.升級openssh之前要先打開伺服器telnet,通過telnet登錄伺服器,因為升級過程中會導致ssh暫時不能用 打開linux telnet服務: 查看telnet是否已經安裝 ...
  • 環境:筆記本 + 家用WIFI + 公司WIFI + VMware + CentOS6.8 + Xshell 問題描述:初學Linux時,用筆記本裝了虛擬機(單網卡),想實現linux在家和公司都能夠無線連網,但又不想上網地點變動之後每次手動輸入IP登錄Xshell。 解決思路:增加一塊網卡(eth ...
  • 一、簡介 1、認識 加密網頁(https): tcp:443 明文網頁(http): tcp:80 survey.netcraft.net --這個網站上可以查到最新的網站伺服器的使用率 超文本傳輸協議(HTTP,HyperText Transfer Protocol)是互聯網上應用最為廣泛的一種網 ...
  • select系統調用的的用途是:在一段指定的時間內,監聽用戶感興趣的文件描述符上可讀、可寫和異常等事件。 select 機制的優勢 為什麼會出現select模型? 先看一下下麵的這句代碼: 這是用來接收數據的,在預設的阻塞模式下的套接字里,recv會阻塞在那裡,直到套接字連接上有數據可讀,把數據讀到 ...
  • 在ASP.NET MVC中來實現主題的切換一般有兩種方式,一種是通過切換皮膚的css和js引用,一種就是通過重寫視圖引擎。通過重寫視圖引擎的方式更加靈活,因為我不僅可以在不同主題下麵佈局和樣式不一樣,還可以讓不同的主題下麵顯示的數據條目不一致,就是說可以在某些主題下麵添加一下個性化的東西。 本篇我將 ...
  • 本文版權歸博客園和作者吳雙本人共同所有 轉載和爬蟲請註明原文地址 www.cnblogs.com/tdws 一.寫在前面 適配器模式(Adapter) 可用來在現有介面和不相容的類之間進行適配。有助於避免大規模改寫現有客戶代碼,其工作機制是對現有類的介面進行包裝,這樣客戶程式就能使用這個並非為其量身 ...
  • 寫在前面整個項目都托管在了 Github 上:https://github.com/ikesnowy/Algorithms-4th-Edition-in-Csharp這一節內容可能會用到的庫文件有 Geometry 和 Commercial,同樣在 Github 上可以找到。善用 Ctrl + F ... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...