標籤:style blog class code tar ext
由於給予REST的Web服務非常簡單易用,它越來越成為企業後端服務整合的首選方法。本文這裡介紹一下如何通過微軟的Asp.Net WebAPI快速構建REST-ful 服務。
首先建立一個Asp.Net Web應用程式(我這裡用的是Visual Studio 2013,它已經內建了Web API2)。
在出來的模板中選擇Empty(空項目),並勾選WebAPI。點擊確定後,就建立了一個空的WebAPI服務。
此時只有一個空項目,還沒有任何功能,在進行下一步之前,首先我們來看一下REST的基本操作模型,大致可以分為如下四種:
- POST — 建立資源
- GET — 檢索資源
- PUT — 更新資源
- DELETE — 刪除資源
非常經典的CRUD模型。在Web API中實現這樣一個的模型是非常簡單的,直接使用嚮導建一個Controller即可
如果用傳統的嚮導,記得把嚮導後面的那個1給去掉:
預設的模板內容如下:
publicclassValuesController : ApiController
{
// GET api/<controller>
publicIEnumerable<string> Get()
{
returnnewstring[] { "value1", "value2" };
}
// GET api/<controller>/5
publicstring Get(int id)
{
return"value";
}
// POST api/<controller>
publicvoid Post([FromBody]string value)
{
}
// PUT api/<controller>/5
publicvoid Put(int id, [FromBody]string value)
{
}
// DELETE api/<controller>/5
publicvoid Delete(int id)
{
}
}
這其實已經幫我們實現了一個最基本的服務了,不過這個服務中只實現了Get,它支援如下兩種中方式的URL訪問(其它的方式也能訪問,但沒有具體的效果):
- api/values 訪問所有的Value列表
- api/values/{id} 根據ID訪問Value
按Ctrl + F5中執行,在瀏覽器中輸入相應的地址即可看到結果
下面我們要做的就是完善它,實現一個簡單的查詢功能,這裡我引用了微軟官方的一個例子:
publicclassProductsController : ApiController
{
Product[] products = newProduct[]
{
newProduct { Id = 1, Name = "Tomato Soup", Category = "Groceries", Price = 1 },
newProduct { Id = 2, Name = "Yo-yo", Category = "Toys", Price = 3.75M },
newProduct { Id = 3, Name = "Hammer", Category = "Hardware", Price = 16.99M }
};
publicIEnumerable<Product> Get()
{
return products;
}
publicIHttpActionResult Get(int id)
{
var product = products.FirstOrDefault((p) => p.Id == id);
if (product == null)
{
return NotFound();
}
return Ok(product);
}
}
publicclassProduct
{
publicint Id { get; set; }
publicstring Name { get; set; }
publicstring Category { get; set; }
publicdecimal Price { get; set; }
}
此時,我們就可以在瀏覽器中看到結果了(由於Controller改名字了,此時的地址就變成了api/products)
到此為止,一個基於Asp.net Web API的 簡單的REST Web服務就構建完成了,由於篇幅所限,這裡就不做更多的介紹了,跟多資訊可以參看微軟官方文檔:Getting Started with ASP.NET Web API 2。另外,如果想對REST有更深入的瞭解的話,可以看看infoq的這篇文章:深入淺出REST。關於Asp.net Web API其它內容,我後續大概還會陸續寫幾篇文章來介紹它。