下面這段代碼添加了 MVC 6 需要的所有依賴項,會自動在啟動時調用ConfigureServices
。
void Configure(IApplicationBuilder app)
{
// :
app.UseMvc();
}
以下是完整的 Startup
類代碼:
System;
Microsoft.AspNet.Builder;
Microsoft.AspNet.Http;
// :
Microsoft.Framework.DependencyInjection;
TodoApi
{
Startup
{
// Add this method:
void ConfigureServices(IServiceCollection services)
{
services.AddMvc();
}
void Configure(IApplicationBuilder app)
{
// :
app.UseMvc();
app.UseWelcomePage();
}
}
}
添加 Modelmodel 代表應用的資料域。在本樣本中,model 中儲存 ToDo 項。 添加以下類到項目中:
System.ComponentModel.DataAnnotations;
TodoApi.Models
{
TodoItem
{
int Id { ; ; }
[Required]
Title { ; ; }
bool IsDone { ; ; }
}
}
為了保持項目的整潔,我建立了 Models 檔案夾用於存放 Model 類,當然這不是必要的操作。
添加 Controller添加 controller 類用於處理 HTTP 要求。添加以下類到項目中:
Microsoft.AspNet.Mvc;
System.Collections.Generic;
System.Linq;
TodoApi.Models;
TodoApi.Controllers
{
[Route("")]
TodoController : Controller
{
List<TodoItem> _items = List<TodoItem>()
{
TodoItem { Id = 1, Title = "" }
};
[HttpGet]
IEnumerable<TodoItem> GetAll()
{
_items;
}
[HttpGet("", Name = "")]
IActionResult GetById (int id)
{
var item = _items.FirstOrDefault(x => x.Id == id);
(item == null)
{
HttpNotFound();
}
ObjectResult(item);
}
[HttpPost]
void CreateTodoItem([FromBody] TodoItem item)
{
(!ModelState.IsValid)
{
Context.Response.StatusCode = 400;
}
else
{
item.Id = 1+ _items.Max(x => (int?)x.Id) ?? 0;
_items.Add(item);
url = Url.RouteUrl("", { id = item.Id },
Request.Scheme, Request.Host.ToUriComponent());
Context.Response.StatusCode = 201;
Context.Response.Headers[""] = url;
}
}
[HttpDelete("")]
IActionResult DeleteItem(int id)
{
var item = _items.FirstOrDefault(x => x.Id == id);
(item == null)
{
HttpNotFound();
}
_items.Remove(item);
HttpStatusCodeResult(204); // 201 No Content
}
}
}
同樣,我建立了 Controllers 檔案夾用於儲存 controller。
在後續的章節中我們將進一步闡述關於 Controller 的代碼。以下是 controller 實現的一些基礎功能:
例如,下面是擷取 ToDo 項目的 HTTP 要求的:
http://localhost:5000/api/todo HTTP/1.1
User-Agent: Fiddler
Host: localhost:5000
下面是 response 流:
HTTP/1.1 200 OK
Content-Type: application/json;charset=utf-8
Server: Microsoft-HTTPAPI/2.0
: Thu, 30 Oct 2014 22:40:31 GMT
Content-Length: 46
[{"":1,"":"","":}]
後續章節中我們將闡述以下內容: