Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Contact Manager Web API 示例[2] Web API Routing

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

作者头像
张善友
发布于 2018-01-22 03:45:54
发布于 2018-01-22 03:45:54
1K0
举报
文章被收录于专栏:张善友的专栏张善友的专栏

联系人管理器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 项目,项目样版会建立默认路由给你:

代码语言:js
AI代码解释
复制
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 请求:

代码语言:js
AI代码解释
复制
       [HttpGet]    
      public HttpResponseMessage<Contact> Get(int id)     
      {     
         ……
      }

Action 名称的路由

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

代码语言:js
AI代码解释
复制
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 方法:

代码语言:js
AI代码解释
复制
       [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 方法。

代码语言:js
AI代码解释
复制
      [NonAction]    
      public Contact GetPrivateContact(int id)     
      {
            ……
      } 
参考资料
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2012-05-12 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Asp.Net Web API 2第五课——Web API路由
    Asp.Net Web API第一课——入门 http://www.cnblogs.com/aehyok/p/3432158.html
aehyok
2018/08/31
1.3K0
Asp.Net Web API 2第五课——Web API路由
Asp.Net Web API(三)
    在Asp.Net Web API中,一个控制器就是一个处理HTTP请求的类,控制器的public方法就被叫做action方法或简单的Action。当Web API接收到一个请求的时候,它将这个请求路由到一个Action。
莫问今朝
2018/08/31
1.8K0
Asp.Net Web API(三)
Asp.Net Web API 2第六课——Web API路由和动作选择
      Asp.Net Web API第一课——入门http://www.cnblogs.com/aehyok/p/3432158.html
aehyok
2018/08/31
1K0
Asp.Net Web API 2第六课——Web API路由和动作选择
ASP.NET Web API路由规则(二)
(注:至于为什么用MapHttpRoute而不是MapRoute;为什么用routeTemplate而不是用url我们再以后的章节介绍)
liulun
2022/05/09
5150
ASP.NET Web API路由规则(二)
Asp.net web api 知多少
本系列主要翻译自《ASP.NET MVC Interview Questions and Answers 》- By Shailendra Chauhan,想看英文原版的可访问http://www.dotnettricks.com/free-ebooks自行下载。该书主要分为两部分,ASP.NET MVC 5、ASP.NET WEB API2。本书最大的特点是以面试问答的形式进行展开。通读此书,会帮助你对ASP.NET MVC有更深层次的理解。 由于个人技术水平和英文水平也是有限的,因此错误在所难免,希
圣杰
2018/01/11
5K0
Asp.net web api 知多少
ASP.NET Web API: 宿主(Hosting)
ASP.NET Web API 处理架构中介绍了ASP.NET Web API主要有三层组成:宿主(hosting),消息处理管道(message handler pipeline)和控制器处理(controller handling),本篇文章主要介绍宿主(Hosting):包括ASP.NET经典管道上的Web Hosting和WCF堆栈的自宿主SelfHosting。 ASP.NET经典管道上的Web Hosting 1、ASP.NET 路由使您可以使用不必映射到网站中特定文件的 URL。 由于该 UR
张善友
2018/01/19
1.4K0
ASP.NET Web API: 宿主(Hosting)
ASP.NET Web API编程——路由
路由过程大致分为三个阶段: 1)请求URI匹配已存在路由模板 2)选择控制器 3)选择操作 1匹配已存在的路由模板 路由模板 在WebApiConfig.Register方法中定义路由,例如模板默认生成的路由为: config.Routes.MapHttpRoute( name: "DefaultApi", routeTemplate: "api/{controller}/{id}", defaults: new
甜橙很酸
2018/04/17
1.8K0
Contact Manager Web API 示例[4] 异常处理(Exception Handling)
联系人管理器web API是一个Asp.net web api示例程序,演示了通过ASP.NET Web API 公开联系信息,并允许您添加和删除联系人,示例地址http://code.msdn.microsoft.com/Contact-Manager-Web-API-0e8e373d。 Contact Manager Web API 示例[1]CRUD 操作 已经做了一个基本的介绍, Contact Manager Web API 示例[2] Web API Routing 介绍Web API Rout
张善友
2018/01/22
8340
通过Knockout.js + ASP.NET Web API构建一个简单的CRUD应用
较之面向最终消费者的网站,企业级Web应用对用户体验的要求要低一些。不过客户对“用户体验”的要求是“与日俱增”的,很多被“惯坏了”的用户已经不能忍受Postback带来的页面刷新,所以Ajax在企业级Web应用中得到了广泛的应用。企业级Web应用的一个特点是以“数据处理”为主,所以“面向绑定”的Knockout.js 是一个不错的选择。ASP.NET Web API,作为.NET平台最好的REST服务开发平台(主要与WCF相比),则可以以服务的形式提供对数据的后台处理。 一、一个简单的基于CRUD的Web应
蒋金楠
2018/01/15
1.3K0
通过Knockout.js + ASP.NET Web API构建一个简单的CRUD应用
通过ASP.NET Web API + JQuery创建一个简单的Web应用
看了dudu的《HttpClient + ASP.NET Web API, WCF之外的另一个选择》一文,想起多很久之前体现ASP.NET Web API而创建的一个Demo。这是一个只涉及到简单CRUD操作的Web应用,业务逻辑以Web API的形式定义并以服务的形式发布出来,前台通过jQuery处理用户交互并调用后台服务。[源代码从这里下载] 目录 一、一个简单的基于CRUD 二、通过ASP.NET Web API提供服务 三、通过JQuery消费服务 一、
蒋金楠
2018/01/15
9230
通过ASP.NET Web API + JQuery创建一个简单的Web应用
在一个空ASP.NET Web项目上创建一个ASP.NET Web API 2.0应用
由于ASP.NET Web API具有与ASP.NET MVC类似的编程方式,再加上目前市面上专门介绍ASP.NET Web API 的书籍少之又少(我们看到的相关内容往往是某本介绍ASP.NET MVC的书籍“额外奉送”的),以至于很多人会觉得ASP.NET Web API仅仅是ASP.NET MVC的一个小小的扩展而已,自身并没有太多“大书特书”的地方。而真实的情况下是:ASP.NET Web API不仅仅具有一个完全独立的消息处理管道,而且这个管道比为ASP.NET MVC设计的管道更为复杂,功能也更
蒋金楠
2018/01/15
4.7K0
在一个空ASP.NET Web项目上创建一个ASP.NET Web API 2.0应用
实战 ASP.NET Web API
Web API 框架是一个面向 Http 协议的通信框架。相对于 WCF 而言,Web API 只面向于 Http 协议设计,而且没有 WCF 那么繁琐的配置。Web API 的开发类似于 ASP.NET MVC 中控制器的开发,但是相对于直接使用 ASP.NET MVC 来返回 Json 对象的方式而言,Web API 封装了数据的序列化、反序列化,接口、实现都更加简单。 简单地说,如果要向浏览器、移动端提供 Json 数据格式的 API,则应该首选 Web API 作为通信框架。 以下,我列出了在当前
用户1172223
2018/01/29
1.4K0
实战 ASP.NET Web API
Contact Manager Web API 示例[1]CRUD 操作
联系人管理器web API是一个Asp.net web api示例程序,演示了通过ASP.NET Web API 公开联系信息,并允许您添加和删除联系人,示例地址http://code.msdn.microsoft.com/Contact-Manager-Web-API-0e8e373d . 下面的文章以这个示例讲解ASP.NET Web API的各方面知识: 1、CRUD操作: CURD 是 "Create, Read, Update, Delete" (新增、读取、更新、删除) 的简写,这四个动作是数据
张善友
2018/01/22
9470
支持Ajax跨域访问ASP.NET Web Api 2(Cors)的简单示例教程演示
随着深入使用ASP.NET Web Api,我们可能会在项目中考虑将前端的业务分得更细。比如前端项目使用Angularjs的框架来做UI,而数据则由另一个Web Api 的网站项目来支撑。注意,这里是两个Web网站项目了,前端项目主要负责界面的呈现和一些前端的相应业务逻辑处理,而Web Api则负责提供数据。 这样问题就来了,如果前端通过ajax访问Web Api项目话,就涉及到跨域了。我们知道,如果直接访问,正常情况下Web Api是不允许这样做的,这涉及到安全问题。所以,今天我们这篇文章的主题就是讨论演
Rector
2018/02/01
1.2K0
Winform开启Web API服务新姿势
首先Nuget中下载包:Microsoft.AspNet.WebApi.SelfHost,如下:
沙漠尽头的狼
2023/12/04
8390
Winform开启Web API服务新姿势
WebApi的多版本管理
1.多版本管理概念      什么是API的多版本问题?Android等App存在着多版本客户端共存的问题:由于早期没有内置升级机制,用户不会升级,拒绝升级等原因,造成了许多软件的旧版本App也在运行
莫问今朝
2018/08/31
1.5K0
WebApi的多版本管理
使用 OWIN Self-Host ASP.NET Web API 2
Open Web Interface for .NET (OWIN)在Web服务器和Web应用程序之间建立一个抽象层。OWIN将网页应用程序从网页服务器分离出来,然后将应用程序托管于OWIN的程序而离开IIS之外,关于OWIN的详细资料可参考博客 MVC5 - ASP.NET Identity登录原理 - Claims-based认证和OWIN。使用OWIN 自宿主 ASP.NET WebAPI 2可以参考以下2篇文章: Use OWIN to Self-Host ASP.NET Web API 2 As
张善友
2018/01/29
1.3K0
WCF Web API 说再见,继承者ASP.NET Web API
从 .NET 3.5 开始 WCF 已经支持用 WebHttpBinding 构建 RESTful Web 服务,基于 WCF 框架的 RESTful Web 服务还是建立在 WCF Message 栈上,还是基于RPC风格的,因为 REST 的工作原理有所不同,它不需要依赖 SOAP 协议,因此 WCF 消息管道对于它经过了特殊的消息优化。但 REST 集成在 WCF 消息管道上还是不理想,所以微软重新开始构造基于Http 协议特点的RESTful的Web API, 从2010年10月份开始把代码放在co
张善友
2018/01/30
1.4K0
WCF Web API 说再见,继承者ASP.NET Web API
快速入门系列--WebAPI--03框架你值得拥有
    接下来进入的是俺在ASP.NET学习中最重要的WebAPI部分,在现在流行的互联网场景下,WebAPI可以和HTML5、单页应用程序SPA等技术和理念很好的结合在一起。所谓ASP.NET WebAPI,其核心概念就是构建REST风格的Web服务,把一起数据视为资源,无论是服务请求或者是数据操作,与以前的SOAP和XML-RPC架构风格有很大不同。说道这,很多读者可能想到WCF中不是早都有了REST风格的服务么,为什么还需要这个WebAPI?确实如此,不过WCF中的该类型服务显得比较复杂,因为其通信管
用户1216676
2018/01/24
2.1K0
快速入门系列--WebAPI--03框架你值得拥有
使用OWIN作为WebAPI的宿主
GuZhenYin
2018/01/04
9750
使用OWIN作为WebAPI的宿主
相关推荐
Asp.Net Web API 2第五课——Web API路由
更多 >
领券
💥开发者 MCP广场重磅上线!
精选全网热门MCP server,让你的AI更好用 🚀
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档