首頁 > 後端開發 > C#.Net教程 > 讓WebAPI 傳回JSON格式的資料實例教學

讓WebAPI 傳回JSON格式的資料實例教學

零下一度
發布: 2018-05-21 11:10:03
原創
10664 人瀏覽過

在RestFul風格盛行的年代,對接接口大多數人會選擇使用JSON,XML和JSON的對比傳送(),看看這位博主是怎麼說的,雖然最後沒有說完,我想大概也能略微解決心中的疑惑。

1.其實要想讓WebAPI 回傳JSON格式的資料很簡單,只要在ConfigureWebapi方法中設定一下即可。先前需要引用兩個命名空間。

using Newtonsoft.Json.Serialization;using System.Linq;
登入後複製

2.核心程式碼如下:

var json = config.Formatters.JsonFormatter;// 解决json序列化时的循环引用问题json.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore;// 移除XML序列化器config.Formatters.Remove(config.Formatters.XmlFormatter);//设置序列化方式为驼峰命名法var jsonFormatter = config.Formatters.OfType<system.net.http.formatting.jsonmediatypeformatter>().First();
 jsonFormatter.SerializerSettings.ContractResolver = new CamelCasePropertyNamesContractResolver();//  Web API 路由config.MapHttpAttributeRoutes();</system.net.http.formatting.jsonmediatypeformatter>
登入後複製

#完整程式碼如下:

        /// <summary>/// 配置WebApi/// </summary>/// <param>public void ConfigureWebapi(IAppBuilder app)
        {//创建一个HTTP的实例配置var config = new HttpConfiguration();var json = config.Formatters.JsonFormatter;// 解决json序列化时的循环引用问题json.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore;// 移除XML序列化器            config.Formatters.Remove(config.Formatters.XmlFormatter);//设置序列化方式为驼峰命名法var jsonFormatter = config.Formatters.OfType<system.net.http.formatting.jsonmediatypeformatter>().First();
            jsonFormatter.SerializerSettings.ContractResolver = new CamelCasePropertyNamesContractResolver();//  Web API 路由            config.MapHttpAttributeRoutes();//映射路由            config.Routes.MapHttpRoute(
                name: "DefaultApi",
                routeTemplate: "api/{controller}/{id}",
                defaults: new { id = RouteParameter.Optional }
            );//将配置注入OWIN管道中            app.UseWebApi(config);
        }</system.net.http.formatting.jsonmediatypeformatter>
登入後複製

##3 .接下來讓我們來測試一下,新增一個名為ProductController的Controller,刪除所有的方法,新增一個GetProductList方法,程式碼如下:

       [HttpGet]public HttpResponseMessage GetProduct()
        {var product = new { id = 1, name = "三星王炸" };

            HttpResponseMessage result = new HttpResponseMessage();
            result.Content = new StringContent(JsonConvert.SerializeObject(product), Encoding.GetEncoding("UTF-8"), "application/json");return result;
        }
登入後複製
4.在瀏覽器中輸入http://localhost :27650/api/product/GetProduct ,輸出結果為

讓WebAPI 傳回JSON格式的資料實例教學

5.我們發現如果在瀏覽器中輸入http://localhost:27650/api/product 同樣也可以得到回傳值,讓我們來簡單改造一下重新再寫一個新方法

        [HttpGet]public HttpResponseMessage GetProduct2(string id)
        {var product = new { id = id, name = "三星王炸" };

            HttpResponseMessage result = new HttpResponseMessage();
            result.Content = new StringContent(JsonConvert.SerializeObject(product), Encoding.GetEncoding("UTF-8"), "application/json");return result;
        }
登入後複製

#6.在瀏覽器中輸入http://localhost:27650/api/product?id =3 和http://localhost:27650/api/product 得到的結果分別為

讓WebAPI 傳回JSON格式的資料實例教學讓WebAPI 傳回JSON格式的資料實例教學

為什麼會出現這種現象呢,大家看看我們開始在設定WebAPI的路由規則,規則是api/{controller}/{id} ,也就是說此規則不會去符合action的名稱,而是根據傳入的參數類型和個數來決定的。

讓WebAPI 傳回JSON格式的資料實例教學

7.那麼如何讓WebAPI 根據方法名稱來匹配呢,讓我們來修改一下路由規則,程式碼如下:

config.Routes.MapHttpRoute(
                name: "DefaultApi",
                routeTemplate: "api/{controller}/{action}/{id}",
                defaults: new { id = RouteParameter.Optional }
            );
登入後複製

 

8.讓我們再測試一下,瀏覽器中輸入http://localhost:27650/api/product,看看效果。

讓WebAPI 傳回JSON格式的資料實例教學

再輸入http://localhost:27650/api/product/GetProduct 和http://localhost:27650/api/product/GetProduct?id=5,發現兩個回傳的結果一樣,說明訪問的是同一個方法。

讓WebAPI 傳回JSON格式的資料實例教學讓WebAPI 傳回JSON格式的資料實例教學

再輸入http://localhost:27650/api/product/GetProduct2 和http://localhost:27650/api/product/GetProduct2?id= 6

結果:

讓WebAPI 傳回JSON格式的資料實例教學

讓WebAPI 傳回JSON格式的資料實例教學

測試通過。

這裡僅作整理,加深印象,以防自己忘記。如有不正確的地方,歡迎不吝指教。

以上是讓WebAPI 傳回JSON格式的資料實例教學的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板