使用ASP.Net WebAPI构建REST服务(一)——简单的示例

因为给予REST的Web服务很是简单易用,它愈来愈成为企业后端服务集成的首选方法。本文这里介绍一下如何经过微软的Asp.Net WebAPI快速构建REST-ful 服务。web

首先建立一个Asp.Net Web应用程序(我这里用的是Visual Studio 2013,它已经内置了Web API2)。后端

    

在出来的模板中选择Empty(空项目),并勾选WebAPI。点击肯定后,就建立了一个空的WebAPI服务。api

    

此时只有一个空项目,尚未任何功能,在进行下一步以前,首先咱们来看一下REST的基本操做模型,大体能够分为以下四种:浏览器

  • POST — 建立资源
  • GET — 检索资源
  • PUT — 更新资源
  • DELETE — 删除资源

很是经典的CRUD模型。在Web API中实现这样一个的模型是很是简单的,直接使用向导建一个Controller便可asp.net

    

    

若是用传统的向导,记得把向导后面的那个1给去掉:spa

 

默认的模板内容以下:.net

    public class ValuesController : ApiController
    {
        // GET api/<controller>
        public IEnumerable<string> Get()
        {
            return new string[] { "value1", "value2" };
        }

        // GET api/<controller>/5
        public string Get(int id)
        {
            return "value";
        }

        // POST api/<controller>
        public void Post([FromBody]string value)
        {
        }

        // PUT api/<controller>/5
        public void Put(int id, [FromBody]string value)
        {
        }

        // DELETE api/<controller>/5
        public void Delete(int id)
        {
        }
    }
3d

这其实已经帮咱们实现了一个最基本的服务了,不过这个服务中只实现了Get,它支持以下两种中方式的URL访问(其它的方式也能访问,但没有具体的效果): rest

  • api/values        访问全部的Value列表    
  • api/values/{id}        根据ID访问Value

按Ctrl + F5中执行,在浏览器中输入相应的地址便可看到结果 blog

    

下面咱们要作的就是完善它,实现一个简单的查询功能,这里我引用了微软官方的一个例子:

public class ProductsController : ApiController
{
        Product[] products = new Product[]
        {
            new Product { Id = 1, Name = "Tomato Soup", Category = "Groceries", Price = 1 },
            new Product { Id = 2, Name = "Yo-yo", Category = "Toys", Price = 3.75M },
            new Product { Id = 3, Name = "Hammer", Category = "Hardware", Price = 16.99M }
        };

        public IEnumerable<Product> Get()
        {
            return products;
        }

        public IHttpActionResult Get(int id)
        {
            var product = products.FirstOrDefault((p) => p.Id == id);
            if (product == null)
            {
                return NotFound();
            }
            return Ok(product);
        }
    }

    public class Product
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string Category { get; set; }
        public decimal 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其它内容,我后续大概还会陆续写几篇文章来介绍它。

相关文章
相关标签/搜索