Contact Manager Web API 示例[2] Web API Routing

联系人管理器web API是一个Asp.net web api示例程序,演示了通过ASP.NET Web API 公开联系信息,并允许您添加和删除联系人,示例地址http://code.msdn.microsoft.com/Contact-Manager-Web-API-0e8e373dContact Manager Web API 示例[1]CRUD 操作 已经做了一个基本的介绍,本文主要介绍Web API Routing。

如果你已经熟悉 ASP.NET MVC,你会发现 Web API Routing(路由)与 MVC 非常类似。主要差异在 Web API 使用 HTTP Method ( GET, POST, PUT, DELETE ...) 而不是使用 URI 路径来选择 Action。你也可以在 Web API 里使用 MVC 样式的路由。以下讨论专注在 Web API 且可以没有 ASP.MVC 基础。

ROUTING TABLES, 路由表

在 ASP.NET Web API,一个 controller 是一个 class(类) 以处理 HTTP 请求(requests)。在 controller 里所有的公开方法(public  methods)都称为 Action方法 或简称 Action。当 Web API Framework 接收到一个请求,它路由请求到一个 Action。 Framework 会使用路由表(Routing Table),决定那一个 Action 会被调用。如果你在 ASP.NET 里使用 Web API,路由表会定义在 Global.asax 档案中。默认使用 Visual Studio 去新增一个 Web API 项目,项目样版会建立默认路由给你:

config.Routes.MapHttpRoute(    
             "Default", // Route name     
             "{controller}/{id}/{ext}", // URL with parameters     
             new { id = RouteParameter.Optional, ext = RouteParameter.Optional } // Parameter defaults     
         ); 

注意,如果你使用 self-host Web API,你必须在 HttpSelfHostConfiguration对象 上直接设定路由表。

每个实体(entry)在路由表里都包含一个路由样板(route template)。Web API 的路由样板默认是 "api/{controller}/{id}",此样板里,"api" 是文字路径片段,{controller} 和 {id} 是定位参数。 当 Web API Framework 接收到一个 HTTP 请求,它会去尝试比对 URI 对路由表的路由样板之一, 如果没有符合的路由,Client 会收到一个 404 错误。例如,以下 URI 会符合默认路由:

· /api/contacts

· /api/contacts/1

当发现一个符合的路由,Web API 会选择 controller 与 action:

· 寻找 controller,Web API 新增 "Controller" 到 {controller} 变数的值。

· 寻找 action,Web API 查看 HTTP 方法,然后查看 action,哪一个名称的开始与是 HTTP 方法名称。例如,一个 GET 请求,Web API 会查看那一个 action 是以 "Get..."  开头,像是 "GetContact" 或 "GetAllContacts"。此惯例使用在 GET, POST, PUT, DELETE 方法。你也能在 controller 里使用属性(attributes)去启用其他 HTTP 方法。

· 在路由样板里其他定位变量,像是 {id},会对应至 action 的参数。

以下有一些可能 HTTP 请求:

Web API Routing and HTTP Method

HTTP Method

URI路径

Action

参数

GET

/api/contacts

GetAllContacts

(无)

GET

/api/contacts/5

GetContactById

5

DELETE

/api/contacts/5

DeleteContact

5

POST

/api/contacts

(无符合)

留意 URI 的 {id} 段落,如果存在,会对应到 action 里的 id 参数。上述范例, controller 定义了两个 GET 方法,一个 id 参数一个 id 参数。另外,POST 请求会失败,因为在 controller 里没有定义 "Post..." 方法。

路由参数, ROUTING VARIATIONS

接下来我们讨论路由参数。

HTTP 方法, HTTP Methods

Web API 使用HTTP 方法的名称惯例(naming convention)来替代。你也可以明确在 action 方法上指定使用 HttpGet, HttpPost, HttpPut, HttpDelete 属性。 例如,以下的 Get 方法会对应至 GET 请求:

       [HttpGet]    
      public HttpResponseMessage<Contact> Get(int id)     
      {     
         ……
      }

Action 名称的路由

在默认路由模板,Web API 使用 HTTP 方法来选择 action。不管如何,你也能建立一个 URI 含有 action 名称的路由。

config.Routes.MapHttpRoute(    
                "Default", // Route name     
                "/api/{controller}/{action}/{id}", // URL with parameters     
                new { id = RouteParameter.Optional} // Parameter defaults     
            );

此路由样板,在 controller 里的 action 方法会与 {action} 参数对应。使用此种路由样式,你必须明确指定允许属性在 HTTP 方法。例如,在 controller 里有一个 Details 方法:

       [HttpGet]    
      public HttpResponseMessage<Contact> Details(int id)     
      {
      }

一个 "/api/contacts/details/1" 的 GET 请求将会对应至 Details 方法。这种路由样式非常类似 ASP.NET MVC,或是接近一个 RPC-style API。在一个 RESTful API,你应该避免在 URI 使用动词(verbs),因为 URI 应该是定义资源而不是action。

非 Action

如果要预防一个 ACTION 被呼叫,可以使用 NONACTION 属性。这是一个信号跟 FRAMEWORK 说此方法不是一个 ACTION 方法。

      [NonAction]    
      public Contact GetPrivateContact(int id)     
      {
            ……
      } 

参考资料

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏谈补锅

ios线程和GCD和队列同步异步的关系

  进程是指在系统中正在运行的一个应用程序。比如同时打开QQ、Xcode,系统就会分别启动2个进程。截图

6034
来自专栏码农阿宇

asp.net core轻松入门之MVC中Options读取配置文件

接上一篇中讲到利用Bind方法读取配置文件 ASP.NET Core轻松入门Bind读取配置文件到C#实例 那么在这篇文章中,我将在上一篇文章的基础上,利...

2564
来自专栏c#开发者

Msmq设计文档(赋源代码)

Msmq设计文档 文件状态: [√] 草稿 [ ] 正式发布 [ ] 正在修改 文件标识: ECI-MSMQ v01 当前版本: 0.5...

3518
来自专栏张善友的专栏

Contact Manager Web API 示例[2] Web API Routing

联系人管理器web API是一个Asp.net web api示例程序,演示了通过ASP.NET Web API 公开联系信息,并允许您添加和删除联系人,示例地...

1996
来自专栏炉边夜话

JNI使用技巧点滴(二)

作者:normalnotebook 背景<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com...

1802
来自专栏熊训德的专栏

Hbase compaction 源码分析一:compaction 概况分析

本文档从框架的源码角度梳理了,hbase 在什么情况下会触发compaction,并通过官方文档说明出发minor 和major compaction的时间点。

5001
来自专栏MasiMaro 的技术博文

PE文件详解(八)

本文转载自小甲鱼PE文件详解系列教程原文传送门 当应用程序需要调用DLL中的函数时,会由系统将DLL中的函数映射到程序的虚拟内存中,dll中本身没有自己的栈...

942
来自专栏大内老A

ASP.NET Core应用的错误处理[2]:DeveloperExceptionPageMiddleware中间件如何呈现“开发者异常页面”

在《ASP.NET Core应用的错误处理[1]:三种呈现错误页面的方式》中,我们通过几个简单的实例演示了如何呈现一个错误页面,这些错误页面的呈现分别由三个对应...

3018
来自专栏salesforce零基础学习

salesforce零基础学习(八十六)Ajax Toolkit (VF页面中使用及javascript action使用)

Ajax Toolkit 参考文档:https://resources.docs.salesforce.com/212/latest/en-us/sfdc/pd...

3026
来自专栏蘑菇先生的技术笔记

探索c#之storm的TimeCacheMap

2237

扫码关注云+社区

领取腾讯云代金券