从ASP.NET Web API 2 (C#)开始说起

[译]Getting Started with ASP.NET Web API 2 (C#)

单击此处查看原文

HTTP不是单单为网页服务的,它更是一种用于构建API(用于暴露服务和数据)的强大平台。HTTP简洁、灵活、无处不在。几乎你能想到的所有平台都有一个HTTP库,所以HTTP服务可以提供给各种各样的客户端,包括:PC浏览器,手机设备,传统桌面应用。

ASP.NET Web API是基于.NET Framework的一种框架,可用于构建web APIs。在本文中,你将使用ASP.NET Web API来构建一个Web API项目,用于提供一系列的产品信息。

本文使用到的软件版本
· Visual Studio 2013
· Web API 2

新建一个Web API项目

在本文中,你将使用ASP.NET Web API来新建一个web API用于提供各种产品信息。前端项目使用jQuery来展示获取的结果。

无

启动Visual Studio,选择首页的新建项目,或者菜单栏: 文件->新建->项目

模板窗口,选择已安装,展开VIsual C#节点,在VIsual C#下,选择Web。在一系列项目模板中,选择ASP.NET Web应用程序,将项目命名为”ProductsApp”然后单击确定

这里写图片描述

新建ASP.NET项目窗口,选择Empty模板,在“为以下对象添加文件夹和核心引用”下,选择Web API,单击确定

这里写图片描述

同样你也可以使用Web API模板来新建一个Web API项目。Web API模板使用ASP.NET MVC来提供API帮助页。我在本文中使用了空模板,因为我想要展示的Web API是不依赖于MVC的。一般来讲,如果你想要使用Web API,不必事先知道ASP.NET MVC。

添加一个Model

一个model就是一个对象,在你的应用中代表着数据。ASP.NET Web API可以自动把你的model序列化为JSON、XML或者其他格式,再将序列化之后的数据写入HTTP response message的body中。只要一个客户端可以解析这种序列化格式,它就将数据反序列化出来。现在绝大部分的客户端都可以解析XML或者JSON,而且客户端也可以在HTTP request message的Accept header中设置自己想要的数据格式。

好的,我们现在来新建一个简单的model来表示产品信息。

如果没看见 解决方案资源管理器 ,可以单击菜单栏的视图->解决方案资源管理器来打开。现在右键单击Models文件夹,选择添加->类

这里写图片描述

将类命名为“Product.cs”,并且将下列属性写入类中。

namespace ProductsApp.Models
{
    public class Product
    {
        public int Id { get; set; }
        public string Name { get; set; }
        public string Category { get; set; }
        public decimal Price { get; set; }
    }
}

添加一个Controller

在Web API中,一个 controller 就是一个用于处理HTTP requests的对象。接下来我们将要新建一个controller,它能够返回一个Product集合,或者根据ID返回单个Product对象。

注意 如果你已经使用过ASP.NET MVC,你会对controller感到非常熟悉。不错,Web API controllers跟MVC controller的确非常相似,不同的是Web API controller继承了ApiController,而非Controller

解决方案资源管理器中,右键单击Controllers文件夹,选择添加->控制器

这里写图片描述

添加基架窗口,选择Web API 2 控制器 - 空,单击添加

这里写图片描述

添加控制器窗口,将其命名为“ProductsController”,单击添加

这里写图片描述

现在基架已经新建了一个名为ProductsController.cs的文件。

这里写图片描述

你不必将controllers放在Controllers文件夹中。文件夹的命名只不过是为了方便组织管理你的源文件。

如果这个文件还未打开,双击它来打开,并且将下面的代码替换上去。

using ProductsApp.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Web.Http;

namespace ProductsApp.Controllers
{
    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> GetAllProducts()
        {
            return products;
        }

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

为了保证例子的简洁,controller中的products都是存了固定的array。当然,在实际项目中,你可能是从数据库中得到数据,或者使用其他的扩展数据源。

这个controller定义了两个方法来返回products:

  • GetAllProducts方法将整个products list作为IEnumerable类型数据返回。
  • GetProduct方法根据Product的ID来查找对应的一个Product

就是它们了!你拥有了一个可以工作的web API。controller中的每个方法就相当于一个或者多个URIs。

Controller MethodURI
GetAllProducts/api/products
GetProduct/api/products/id

GetProduct方法对应URI中的 id 是个占位符。比如,如果你想获取id为5的product,那么你请求的URI应该是 api/products/5

如果想要获取更多关于Web API routes HTTP requests与controller方法的信息,参考:Routing in ASP.NET Web API

使用JavaScript和jQuery调用Web API

在本节,我们将添加一个HTML page,通过AJAX来调用web API。接下来我们使用jQuery的AJAX来调用,并且将返回结果更新到界面上。

在解决方案资源管理器中,右键单击项目,选择添加->新建项目

这里写图片描述

添加新项窗口中,选择Visual C#->Web->HTML页,并将其命名为“index.html”。

这里写图片描述

用以下的代码替换文件中的所有内容:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>Product App</title>
</head>
<body>

  <div>
    <h2>All Products</h2>
    <ul id="products" />
  </div>
  <div>
    <h2>Search by ID</h2>
    <input type="text" id="prodId" size="5" />
    <input type="button" value="Search" onclick="find();" />
    <p id="product" />
  </div>

  <script src="http://ajax.aspnetcdn.com/ajax/jQuery/jquery-2.0.3.min.js"></script>
  <script>
    var uri = 'api/products';

    $(document).ready(function () {
      // Send an AJAX request
      $.getJSON(uri)
          .done(function (data) {
            // On success, 'data' contains a list of products.
            $.each(data, function (key, item) {
              // Add a list item for the product.
              $('<li>', { text: formatItem(item) }).appendTo($('#products'));
            });
          });
    });

    function formatItem(item) {
      return item.Name + ': $' + item.Price;
    }

    function find() {
      var id = $('#prodId').val();
      $.getJSON(uri + '/' + id)
          .done(function (data) {
            $('#product').text(formatItem(data));
          })
          .fail(function (jqXHR, textStatus, err) {
            $('#product').text('Error: ' + err);
          });
    }
  </script>
</body>
</html>

有很多方式可以获取jQuery。在本例中,我使用了Microsoft Ajax CDN,你也可以从http://jquery.com/下载。当然,ASP.NET Web API项目模板也包含了jQuery。

获取Products List

发送一条HTTP GET request:”/api/products”,可以获取Products List。

jQuery的getJSON方法可以发送一条AJAX request。为了响应结果包含JSON对象数组,done方法指定了一个回调函数,它将会在请求成功后触发。在回调函数中,我们可以将请求到的product信息更新到DOM中。

$(document).ready(function () {
    // Send an AJAX request
    $.getJSON(apiUrl)
        .done(function (data) {
            // On success, 'data' contains a list of products.
            $.each(data, function (key, item) {
                // Add a list item for the product.
                $('<li>', { text: formatItem(item) }).appendTo($('#products'));
            });
        });
});

根据ID获取一个Product

发送一个HTTP GET request:”/api/products/id”,可以获取一条Product(其中id是Product ID)。

function find() {
    var id = $('#prodId').val();
    $.getJSON(apiUrl + '/' + id)
        .done(function (data) {
            $('#product').text(formatItem(data));
        })
        .fail(function (jqXHR, textStatus, err) {
            $('#product').text('Error: ' + err);
        });
}

我们依然调用getJson来发送AJAX request,不过这次我们将ID放在URI中。请求响应的结果是一条JSON格式的Product。

运行应用程序

按下F5来开始调试应用,界面看起来就像下图所示:

这里写图片描述

若想根据ID获取一条Product,输入ID并且单击Search:

这里写图片描述

如果你输入了非法ID,服务器将返回HTTP error:

这里写图片描述

介绍浏览器开发者工具的懒得翻译,就一件事:F12

在Azure上运行的也是懒得翻译,就一个概念:微软的一个云服务,有兴趣去了解一下 单击此处转到Microsoft Azure

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
我觉得大部分人都是“眼球动物“,他们关注的往往都是目光所及的东西。对于很多软件从业者来说,他们对看得见(具有UI界面)的应用抱有极大的热忱,但是对背后支撑整个应用的服务却显得较为冷漠。如果我们将整个“生态系统”比喻成海面上漂浮的冰山,我们所能看的到的只是露出水面的冰山一角,水面之下才是一个“庞然大物”。 提到服务,我们自然想到Web Service。但是传统意义上的Web Service却有点名不副实,因为支撑它的其实不是Web而是SOAP,承载一个Web Service甚至可以根本不需要Web。随着互联网的普及,互联网应用(尤其移动互联网应用)已经成为主流,“SOAP之重”已经越来越令我们无法承受,于是采用REST架构风格并直接采用Web进行通信的轻量级Web Service走进了我们的视野并登堂入室。为了与传统的基于SOAP的Web Service以示区别,我们将后者称为Web API。 很多人鼓吹SOAP已死,我个人对此持不同的看法。上面讲的“重”与“轻”都是不带任何感情色彩的中性词,至于优劣评价则决定于它们是否适合应用的场景。到目前为止,对于企业级应用之间的内部集成互联,我觉得传统的Web Service依然是最好的选择。传统Web Service应用的领域貌似在不断被Web API占据,但是后者并不能完全被视为前者的替代品,它只是让“踩过界”的Web Service退回到它应该坚守的领地。Web Service和Web API在各自适合的领域各司其职,使“路归路、桥归桥”是一种理想的状态。 Web Service和Web API的合理布局同样也体现在微软技术平台上。WCF在过去是唯一的选择,这是一个具有“SOAP”基因的通信平台,微软后来利用扩展让它提供了针对REST的支持。正因为如此,如果使用WCF来构建Web API的话,我们依然需要采用传统的编程方式,Web API的“简单、快捷”完全得不到体现。微软意识到在一个“重量级”通信框架上通过扩展实现“轻量级”的通信,还不如重新构建一个通信平台,于是ASP.NET Web API应运而生。
### 回答1: ASP.NET Web API 2框架揭秘是一本针对ASP.NET Web API 2框架进行深入介绍的电子书。ASP.NET Web API 2是一个用于构建基于HTTP协议的Web服务的开发框架。这本电子书透过简单直接的方式,帮助读者更好地理解和应用该框架。 在这本电子书中,我们将介绍Web API 2框架的核心概念和基本的工作原理。读者将了解到Web API 2的基本架构和特性,以及如何通过配置和扩展来实现自定义需求。我们还会涉及到常见的Web API设计模式、RESTful架构以及数据传输和安全方面的问题。 通过这本电子书,读者将深入了解Web API 2框架的关键概念,如控制器、动作方法、路由、返回类型和过滤器等。我们会通过实际示例来说明如何创建和调用Web API,并介绍如何处理输入数据、输出结果和错误处理等方面的问题。 此外,这本电子书还将讨论Web API 2框架与其他ASP.NET技术如MVC框架的关系,以及如何在实际项目中使用一些常用的工具和库来提高开发效率和代码质量。 总结而言,ASP.NET Web API 2框架揭秘电子书是一本完整而全面的指南,旨在帮助开发者快速入门和深入理解Web API 2框架,从而能够更好地应用于开发符合现代Web标准的高性能、可扩展和安全的Web服务。无论是初学者还是有经验的开发者,都能从这本电子书中获得实用的知识和技巧。 ### 回答2: ASP.NET Web API 2框架揭秘电子书是一本详细介绍ASP.NET Web API 2框架的电子书。ASP.NET Web API 2 是一个用于构建Web API应用程序的框架,它可以让开发者轻松地构建Web服务,并将其与各种客户端应用程序(如Web、移动设备和桌面应用程序)进行交互。 这本电子书详细介绍了ASP.NET Web API 2框架的工作原理、核心组件、常见用法和最佳实践。它从请求的路由到返回的响应的整个过程进行了解剖,帮助读者理解框架的内部工作机制。 电子书中涵盖了许多重要的概念,如控制器、路由、模型绑定、过滤器等。它解释了如何创建和配置Web API控制器,并讨论了一些高级主题,如版本控制、身份验证和授权。 此外,电子书还介绍了如何使用ASP.NET Web API 2框架来处理不同类型的数据,如JSON、XML和表单数据。它还讨论了如何处理常见的错误和异常,并提供了一些建议和实践,以优化性能和安全性。 总的来说,ASP.NET Web API 2框架揭秘电子书是一本帮助开发者深入了解ASP.NET Web API 2框架的权威指南。它适用于那些有一定ASP.NET开发经验的开发者,并且可以帮助他们更好地利用ASP.NET Web API 2框架来构建高效、可扩展和安全的Web API应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值