符合中小企业对网站设计、功能常规化式的企业展示型网站建设
本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...
商城网站建设因基本功能的需求不同费用上面也有很大的差别...
手机微信网站开发、微信官网、微信商城网站...
ASP.NET Web API2框架揭秘(.NET领域再现力作顶级专家精讲微软全新轻量级通信平台)
创新互联建站专注于网站建设,为客户提供成都做网站、网站设计、网页设计开发服务,多年建网站服务经验,各类网站都可以开发,成都品牌网站建设,公司官网,公司展示网站,网站设计,建网站费用,建网站多少钱,价格优惠,收费合理。蒋金楠 著
ISBN 978-7-121-23536-8
2014年7月出版
定价:108.00元
732页
16开
编辑推荐
√这是一本注重实证的书,功能各异、多达120个可供下载的示例,大量最佳实践与实用性扩展,可直接用于解决实际开发问题。
√全新的学习方法,通过完整论证来实现彻底的融会贯通。
√本书可以作为讲设计架构的书来读,因为其以经过长期检验的经典架构作为学习素材,可很好地启发深度思考。
√讲原理的书同样足够实用。了解ASP.NET Web API框架的运行原理,才能写出最迎合框架的高效程序,才能找到解决具体项目问题的最佳扩展点。
√这是一本帮助你提升内功的书。虽然编程模式可以速成,但本书还是希望你最好对ASP.NETWeb API或ASP.NET MVC有基本概念。
内容提要
《ASP.NET Web API 2框架揭秘》以实例演示的方式介绍了很多与ASP.NET Web API 相关的最佳实践,同时还提供了一系列实用性的扩展。《ASP.NET Web API 2框架揭秘》详细讲解了ASP.NETWeb API 从接收请求到响应回复的整个流程,包括路由、HttpController 的激活、Action 方法的选择与执行、参数的绑定与验证、过滤器的执行和安全等相关的机制。
除此之外,《ASP.NET Web API 2框架揭秘》在很多章节还从设计的角度对ASP.NET Web API 的架构进行了深入分析,所以可以将《ASP.NET Web API 2框架揭秘》当作一本架构设计的书来读。
虽然与市面上任何一本相关的书相比,《ASP.NET Web API 2框架揭秘》走得更远并更加近距离地触及到ASP.NET Web API 框架的内核,但是就其内容本身来讲却没有涉及太多“高深莫测”的知识点,所以阅读《ASP.NET Web API 2框架揭秘》不存在太高的门槛。如果你觉得自己对ASP.NET Web API 所知甚少,可以利用《ASP.NETWeb API 2框架揭秘》来系统地学习ASP.NET WebAPI;如果你觉得自己对ASP.NET Web API 足够精通,也一定能够通过阅读《ASP.NET Web API 2框架揭秘》发现自己知识的“盲点”。
目录
第1 章 概述.....................1
1.1 何为Web.............................2
1.1.1 TCP/IP 与HTTP..................2
1.1.2 Web 资源...................................4
1.1.3 HTTP 事务................................6
1.1.4 HTTP 报文..........................7
1.2 RESTful WebAPI..................................8
1.2.1 为什么叫这个奇怪的名字..................9
1.2.2 RESTful WebAPI 具有怎样的特征.......................10
1.3 初识ASP.NET WebAPI...............................18
1.3.1 构建解决方案.......................18
1.3.2 定义WebAPI........................20
1.3.3 以Web Host 方式寄宿Web API ..................21
1.3.4 以Self Host 方式寄宿Web API..........................27
1.3.5 利用HttpClient 调用Web API ..........................28
1.3.6 创建一个“联系人管理器”应用......................31
第2 章 路由...............................41
2.1 ASP.NET 路由...............................42
2.1.1 请求URL 与物理文件的分离....................42
2.1.2 实例演示:通过URL 路由实现请求地址与Web 页面的映射...........43
2.1.3 ASP.NET 路由系统..................................47
2.1.4 注册路由映射...............55
2.1.5 根据路由规则生成URL..............................68
2.1.6 HttpHandler 的动态映射............................70
2.2 ASP.NET Web API路由.................................73
2.2.1 请求与响应.....................73
2.2.2 ASP.NET WebAPI 路由系统..................77
2.2.3 注册路由映射.................91
2.3 两个路由系统的衔接.........................94
2.3.1HostedHttpRoute 与HostedHttpRouteCollection ............94
2.3.2HttpControllerRouteHandler 与HttpControllerHandler ............. 100
第3 章 消息处理管道................ 103
3.1HttpMessageHandler 管道........................ 104
3.1.1HttpMessageHandler ....................................... 104
3.1.2DelegatingHandler ......................................... 106
3.1.3 HttpServer.................................................. 107
3.1.4HttpRoutingDispatcher........................................114
3.2 Web Host 模式下的消息处理管道...............119
3.2.1HttpControllerHandler ...........................................119
3.2.2 实例演示:自定义HttpMessageHandler实现HTTP 方法重写(S305) .... 126
3.3 Self Host 模式下的消息处理管道..........................130
3.3.1 HttpBinding........................... 130
3.3.2HttpSelfHostServer.......................... 136
第4 章 HttpController 的激活......................145
4.1HttpController...................... 146
4.1.1HttpControllerContext................ 147
4.1.2HttpControllerDescriptor ....... 147
4.1.3ApiController..................................................... 149
4.2 HttpController 是如何被创建的...................151
4.2.1 程序集的解析.................................................151
4.2.2HttpController 类型的解析..................... 161
4.2.3 HttpController的选择..................................... 165
4.2.4HttpController 的创建................................ 173
4.2.5HttpController 的激活与释放............... 178
4.3 IoC 的应用.....................................................183
4.3.1 利用Unity 来认识IoC.......................... 183
4.3.2 基于IoC 的HttpControllerActivator.................... 185
4.3.3 基于IoC 的DependencyResolver............................ 188
第5 章 Action 的选择........................ 191
5.1HttpActionDescriptor..................... 192
5.1.1 ReflectedHttpActionDescriptor............ 193
5.1.2ActionNameAttribute ............. 194
5.1.3 方法名决定HTTP 方法................................ 195
5.1.4ActionHttpMethodProvider....................................... 197
5.1.5 针对特性的缓存.............................................200
5.2HttpParameterDescriptor.............. 201
5.2.1ReflectedHttpParameterDescriptor................................ 202
5.2.2 实例演示:解析Action方法参数描述信息................ 204
5.3HttpActionSelector ........................ 205
5.3.1 ApiControllerActionSelector....................206
5.3.2 有效的Action 方法............................ 207
5.3.3 目标Action 方法的选择..................... 208
第6 章 特性路由...................... 218
6.1 特性路由注册.......................219
6.1.1HttpRouteInfoProvider 特性....................... 219
6.1.2 基本路由映射...........................................220
6.1.3 让URL 模板能够尽可能反映资源的层次结构.................... 222
6.1.4 为路由变量设置约束......................226
6.1.5 通配符路由变量......................................227
6.1.6 缺省路由变量.........................................228
6.1.7 设置URI 前缀....................................... 230
6.2 约束表达式的解析...........................................231
6.2.1RangeRouteConstraint ................. 232
6.2.2InlineConstraintResolver ............. 233
6.2.3 自定义约束...................237
6.3 路由解析.....................241
6.3.1RouteCollectionRoute ............. 241
6.3.2 实例演示:查看特性路由注册生成的RouteCollectionRoute 对象........ 243
6.3.3 子路由对象的创建...................248
6.3.4 HttpRouteData的生成........... 255
第7 章 Model 绑定(上篇) .......... 262
7.1 Model 绑定解决怎样的问题.............263
7.1.1 基于HttpRouteData的参数绑定............. 263
7.1.2 基于查询字符串的参数绑定..............267
7.2 Model 元数据的解析...................................268
7.2.1 Model 元数据的层次化结构.................268
7.2.2ModelMetadata............ 270
7.2.3ModelMetadataProvider............ 278
7.3 ValueProvider.................. 282
7.3.1ValueProviderResult ............................ 282
7.3.2NameValuePairsValueProvider .......... 285
7.3.3RouteDataValueProvider 与QueryStringValueProvider ...... 295
7.3.4CompositeValueProvider ........... 296
7.4ValueProviderFactory ............ 296
7.4.1RouteDataValueProviderFactory 与QueryStringValueProviderFactory.. 297
7.4.2CompositeValueProviderFactory........... 298
7.4.3ValueProviderFactory 的注册................................ 299
7.4.4 自定义ValueProviderFactory.....301
第8 章 Model 绑定(下篇) ............. 304
8.1 ModelBinder................ 305
8.1.1ModelBindingContext.......... 306
8.1.2 去除前缀后的二次绑定...........307
8.1.3CompositeModelBinder ............ 309
8.2ModelBinderProvider......................... 310
8.2.1CompositeModelBinderProvider................311
8.2.2ModelBinderAttribute ........... 312
8.2.3 Model 绑定的流程......................313
8.3 针对不同目标类型的Model绑定....................... 314
8.3.1 简单类型..............315
8.3.2 复杂类型...................318
8.3.3 集合...................327
8.3.4 数组................340
8.3.5 字典................343
8.3.6 最后一个ModelBinder........ 350
8.4ModelState............... 355
8.4.1 ApiController的ModelState ........................ 355
8.4.2 实例演示:获取Model 绑定过程中由ValueProvider 提供的数据(S808).... 357
第9 章 参数的绑定............... 359
9.1 参数绑定系统全景展示...............360
9.1.1HttpParameterBinding.......... 361
9.1.2ActionValueBinder............. 362
9.2 5 个原生的HttpParameterBinding............ 365
9.2.1ModelBinderParameterBinding ............ 365
9.2.2FormatterParameterBinding ................ 368
9.2.3HttpRequestParameterBinding......... 387
9.2.4CancellationTokenParameterBinding ....... 388
9.2.5ErrorParameterBinding ........ 390
9.3HttpParameterBinding 的创建策略.......................... 392
9.3.1ParameterBindingAttribute 特性.............. 392
9.3.2 注册参数绑定规则..............................397
9.3.3HttpParameterBinding 的创建策略................ 400
第10 章 参数的验证........... 406
10.1 几种参数验证方式..............407
10.1.1 手工验证绑定的参数...............407
10.1.2 使用ValidationAttribute特性..................411
10.1.3 创建自我验证数据类型...........................416
10.2 以ModelValidator为核心的参数验证系统................... 418
10.2.1DataAnnotationsModelValidator ........... 421
10.2.2 RequiredMemberModelValidator...........422
10.2.3ValidatableObjectAdapter.......... 425
10.2.4ErrorModelValidator ............ 426
10.3 基于数据注解特性的参数验证.......................431
10.3.1ValidationAttribute 特性.............. 431
10.3.2DataAnnotationsModelValidator ............. 437
10.3.3DataAnnotationsModelValidatorProvider......... 439
10.4 参数验证流程............442
10.4.1ModelValidationNode ............. 443
10.4.2 “验证树”是如何被建立起来的................. 448
10.4.3 “必需”数据成员的验证...........................457
10.4.4 BodyModelValidator............... 462
第11 章 Action 的执行.................. 472
11.1 Action 方法的执行..................473
11.1.1HttpActionInvoker ........... 473
11.1.2ActionExecutor............... 477
11.2 内容协商..................484
11.2.1ContentNegotiator............. 484
11.2.2MediaTypeFormatter 是如何被筛选出来的.............. 486
11.2.3 如何确定响应字符集.............................498
11.3HttpActionResult ................. 501
11.3.1 无响应主体的HttpActionResult....................... 502
11.3.2 含响应主体的HttpActionResult..................... 506
11.3.3ResponseMessageResult .......... 517
11.4HttpResponseMessage 的生成.............. 518
11.4.1ActionResultConverter........... 518
11.4.2 从消息处理管道来看HttpResponseMessage的生成................... 523
第12 章 过滤器........................ 527
12.1 Filter 及其提供机制....................528
12.1.1Filter........ 528
12.1.2FilterProvider............... 531
12.1.3 5 种Filter 类型.................. 539
12.2 认证与授权..................540
12.2.1Identity............. 540
12.2.2 Principal................... 544
12.2.3AuthenticationFilter............. 548
12.2.4AuthorizationFilter ............... 554
12.3 针对Action 方法执行前后的拦截................. 558
12.3.1ActionFilterAttribute................ 559
12.3.2 实例演示:利用自定义ActionFilter实现对Action 方法执行结果的缓存..............565
12.4 异常处理与Filter 的屏蔽........... 572
12.4.1ExceptionFilter............... 572
12.4.2 实例演示:利用自定义的ExceptionFilter集成EntLib 进行异常处理(S1208) ............ 574
12.4.3OverrideFilter ................ 579
第13 章 安全..................... 585
13.1 IIS/ASP.NET 认证..............586
13.1.1 Basic 认证...................586
13.1.2 Digest 认证..................591
13.1.3 集成Windows 认证............. 594
13.1.4 Forms 认证.......................602
13.2 SSL/TLS............ 608
13.2.1 非对称加密...............608
13.2.2 通过SSL/TLS 实现传输安全............... 614
13.2.3 SSL/TLS 的应用...............615
13.3 第三方认证....................619
13.3.1 OAuth 2.0 简介..................620
13.3.2 ImplicitAuthorization Grant ........................ 624
13.3.3Authorization Code Authorization Grant .............. 632
第14 章 跨域资源共享.............. 643
14.1 同源策略.................644
14.1.1 实例演示:跨域调用WebAPI.............. 645
14.1.2 JSONP............ 648
14.2 CORS 规范.............654
14.2.1 资源的授权...............654
14.2.2 实例演示:利用自定义的MessageHandler支持跨域资源共享......... 658
14.3 CORS 在ASP.NET WebAPI 中的实现................ 667
14.3.1 实例演示:采用ASP.NETWeb API 原生的机制实现跨域资源共享(S1406)......... 668
14.3.2 CORS 授权策略及其提供机制.............670
14.3.3 资源授权的检验和CORS 响应报头的生成............. 675
14.3.4CorsMessageHandler............... 678
第15 章 Web API 的调用................. 685
15.1 HttpClient.............. 686
15.1.1HttpMessageInvoker ......... 686
15.1.2HttpClientHandler......... 687
15.1.3HttpClient............. 697
15.2 客户端消息处理管道................700
15.2.1HttpMessageHandler 管道...................... 700
15.2.2HttpClientFactory .......... 703
15.3 面向“对象”编程....................704
15.3.1 将数据对象写入请求消息....................704
15.3.2 读取HTTP 消息主体内容并反序列化为数据对象........... 707
附录A 实例列表.......... 709
媒体推荐
互联网应用尤其是移动互联网应用的普及,让采用Web直接通信的轻量级Web Service成为主流,本书要讲的正是ASP.NET Web API。它是一个全新的通信平台,因为微软没有选择在重量级框架上通过扩展实现轻量级通信。本书宗旨是清晰呈现消息处理管道,以使读者完全理解从接收请求到响应回复的全流程,并彻底掌握路由、HttpController激活、Action方法的选择与执行、参数的绑定与验证、过滤器的执行和安全等相关机制。
作者简介
蒋金楠(网名Artech),《WCF全面解析(上、下册)》《ASP.NET MVC 4框架揭秘》《ASP.NET MVC 5框架揭秘》等多部畅销IT图书作者,现就职于一知名软件公司担任高级软件顾问。拥有一个访问量超过200万的个人博客,2012年度51CTO IT博客大赛10佳得主。2007—2013年被连续7次评为微软MVP,同时也是少数几个跨多领域(Solutions Architect、Connected System、Microsoft Integration和ASP.NET/IIS )的MVP之一。
作者博客: http://www.cnblogs.com/artech
作者微博: http://www.weibo.com/artech
电子邮箱:jiangjinnan@gmail.com
微信公众账号:Artech2981
前言
我觉得大部分人都是“眼球动物”,他们关注的往往都是目光所及的东西。对于很多软件从业者来说,他们对看得见(具有UI界面)的应用抱有极大的热忱,但是对背后支撑整个应用的服务却显得较为冷漠。如果我们将整个“生态系统”比喻成海面上漂浮的冰山,我们所能看到的只是露出水面的冰山一角,水面之下才是一个“庞然大物”。
提到服务,我们自然想到Web Service。但是传统意义上的WebService却有点名不副实,因为支撑它的其实不是Web而是SOAP,承载一个Web Service甚至可以根本不需要Web。随着互联网的普及,互联网应用(尤其移动互联网应用)已经成为主流,“SOAP之重”已经越来越令我们无法承受,于是采用REST架构风格并直接采用Web进行通信的轻量级Web Service走进了我们的视野并登堂入室。为了与传统的基于SOAP的Web Service进行区分,我们将后者称为Web API。
很多人鼓吹SOAP已死,我个人对此持不同的看法。上面讲的“重”与“轻”都是不带任何感情色彩的中性词,至于优劣评价则决定于它们是否适合应用的场景。到目前为止,对于企业级应用之间的内部集成互联,我觉得传统的Web Service依然是最好的选择。传统WebService应用的领域貌似在不断被Web API占据,但是后者并不能完全被视为前者的替代品,它只是让“踩过界”的Web Service退回到它应该坚守的领地。WebService和Web API在各自适合的领域各司其职,形成一种理想的“路归路、桥归桥”的状态。
Web Service和Web API的合理布局同样也体现在微软技术平台上。WCF在过去是唯一的选择,这是一个具有“SOAP”基因的通信平台,微软后来利用扩展让它提供了针对REST的支持。正因为如此,如果使用WCF来构建Web API的话,我们依然需要采用传统的编程方式,Web API的“简单、快捷”完全得不到体现。微软意识到在一个“重量级”通信框架上通过扩展实现“轻量级”的通信,还不如重新构建一个通信平台,于是ASP.NET Web API应运而生。
这不是一本传统意义上的入门书籍
任何一本书都具有对应的受众群体,所以我不得不将这句话放在最前面,并且希望所有打算购买此书的读者能够看到。如果你之前对ASP.NET Web API(或者ASP.NET MVC)完全没有概念,在某一天突然被安排去开发一个需要使用到ASP.NET Web API的项目,你希望有那么一本书能够在一个星期或者更短的时间内帮助你掌握ASP.NET Web API基本的编程方式,那么这本书不适合你。
我个人很喜欢金庸和古龙的武侠小说,我觉得学习某种开发框架就像是练一门武功。一门武功具有“招式”和“心法”之分,外在的招式可以速成,而内功心法绝非一蹴而就,但是没有内功心法支撑的招式只是花拳绣腿。对于某种开发框架来说,基本的编程模式就是招式,框架本身的设计就是心法。
“训练招式”和“传授心法”的书我们都需要,并且不能根据这点来评判一本书的优劣。就本书而言,这是一本苦练内功心法的书。对于大部分读者来说,我觉得在很短的时间内完全掌握本书的内容并不是一件容易的事情,所以如果你没有决定花较多的时间和精力阅读此书的话,我还是建议你选择其他相关的书籍。
我在《ASP.NET MVC 4框架揭秘》一书中写过这么一段话:“掌握ASP.NET MVC具有三个层次,了解基本的编程模式为第一层次,能够清晰认识ASP.NET MVC框架本身从请求接收到响应回复的整个流程为第二层次,最高的层次则是能够灵活自由地利用ASP.NET MVC提供的扩展点解决开发过程的实际问题”。这句话同样适用于针对ASP.NET WebAPI的学习,本书写作的目的是使第一层次的读者快速进入第二层次和第三层次。
这是一本实用的书吗
可能有人觉得这本讲述ASP.NET Web API架构设计和剖析框架运行原理的书没有什么“实际”的意义,因为我们每天的日常工作就是编程,知道了ASP.NET Web API从请求接收到响应回复之间的整个处理流程并不会对实际工作产生实质性的改变。其实这种想法是极端错误的,因为我们编写的程序最终是在框架上运行的,程序的高效性决定于它是否能够大限度地“迎合”框架的运行机制,所以了解ASP.NET Web API框架的运行原理有利于我们写出高质量的程序。
常年以来,我个人的主要工作就是维护和设计公司内部的一个开发框架。这是一个在集团内部广泛采用的针对.NET的开发框架,它的存在使流水线式的软件开发成为可能,这个框架不仅仅提高了生产效率和产品质量,还降低了对最终开发人员技能的要求。之所以能够做到这一点,原因在于几乎所有与业务无关的功能(比如日志、异常处理、权限控制、安全审核、事务处理等)都由这个框架来完成,最终的开发人员只需要实现具体的业务逻辑就可以了。
对于这个开发框架来说,针对相应开发技术所做的扩展和工具是一个重要的组成部分,所以出于本职工作的需要,我不得不对采用的主流开发技术进行深入研究,因为只有在对其内部运行原理了然于胸的情况下才能精准地找到一个最适合的扩展点来解决具体项目开发过程中遇到的问题。很多读者都问过我同样一个问题:“为什么你能够了解那么多关于WCF、ASP.NET MVC和ASP.NET Web API这些技术的内部细节?”我现在告诉你们答案:因为这是我本职工作的一部分。为了将这些实用的研究成果服务于更多的人,我将它们写到我的多本书中。
可以将本书当成一本讲述设计架构的书来读
在我的周围存在着这样一些人,这些人以刚毕业一两年的大学生为主,他们大都工作勤奋、聪明好学,手中经常捧着GoF的《设计模式》,总是希望将书中的设计模式应用到具体项目之中,或者希望通过项目的实践来印证他们在书本上学到的设计模式,但是理论和实践之间的距离总让他们感到困惑。
要从真实的项目或者产品中学习“实用”的软件架构设计知识,先得确定目标项目或者产品中采用的架构思想和设计模式是正确的,而我们参与的很多项目其实被“架构”得一塌糊涂。对于像ASP.NET这样的产品,其基础架构能够在很长一段时间内保持不变,本身就证明了应用在上面的架构设计的正确性,它们不正是我们学习架构设计最好的素材吗!
就我个人而言,很多设计架构方面的知识都是近年来在深入研究WCF、ASP.NET MVC、ASP.NET Web API、EnterpriseLibrary和Unity这些开发技术和开源框架的过程中获取的。对于那些只会拿猫、狗这些东西举例的设计模式的书籍来说,这些内容是学不到的。本书除了介绍一些技术细节,实际上还将ASP.NET Web API的整个架构设计展现在了读者面前,相信有心的读者会从中学到不少关于架构设计方面的知识。
如果你手头刚好有一本《ASP.NET MVC 4框架揭秘》(《ASP.NETMVC 5框架揭秘》也即将出版),可以将这两本书对照着一起看。对于相同的功能点,认真思考一下为何它们在ASP.NET MVC和ASP.NET Web API中会采用不同的设计,两种设计孰优孰劣,我想收获会更大。
本书承载了个人针对新技术的学习方法
在过去几年中,有些热心的读者和网友都向我咨询过一个问题:“对于一门新的技术,如何能够在短时间内掌握其精髓”。这是一个学习方法的问题,虽然我觉得每个人都有适合自己的学习方法,但我还是刻意地将我个人采用的方式体现在本书之中,希望它对某些读者有用。如果读者是个有心人,应该可以看到我在介绍某个知识点的时候,不仅仅会告诉你“是什么”和“为什么”,还会告诉你“如何证明是这样”。换句话说,我不仅仅将某个论点抛给你,还为你展现了整个论证的过程,实际上我在学习过程中就是这么做的。
本书的写作特点
本书具有一个与其他中文原创或者翻译书籍截然不同的特点,那就是几乎所有的术语都采用英文,比如HttpController、Action和Model,在本书中并没有翻译成中文“HTTP控制器”、“操作”和“模型”。因为我认为很多术语其实很难找到一个语义完全等同的中文词组或短语与之对应,对于习惯了将英文作为“开发语言”的读者来说,强行翻译其实是不必要的。
除此之外,这不是一本纯理论的书,而是一本“实证型”的书,在书中提供了120个可供单独下载的实例。这些实例在本书中具有不同的作用,有的是为了探测和证明对应的论点,有的是为了演示所使用的某种编程技巧。
本书读者
虽然这不是一本传统意义上的入门书籍,但是我不会根据读者的技能将某一部分人排除在本书的读者之外。与市面上绝大部分同类书籍相比,我宁愿说这本书走得更远而不是钻得更深,因为虽然本书更加近距离地触及了ASP.NET Web API框架内核,但是涉及的内容本身并没有什么高深莫测之处,对于具有基本.NET基础的读者应该都看得懂。所以我觉得本书适合那些对深层次了解ASP.NET Web API的开发人员和架构师,不论读者处于怎样的层次总会找到自己知识的“盲点”。
关于作者
蒋金楠(网名Artech),《WCF全面解析》(上、下册)、《ASP.NET MVC 4框架揭秘》《ASP.NETMVC 5框架揭秘》等多部畅销IT图书作者,现就职于一家知名软件公司担任高级软件顾问。拥有一个访问量超过200万的个人博客(http://www.cnblogs.com/artech),被评为2012年度51 CTO 十大杰出IT博客。2007~2013年被连续7次评为微软MVP,同时也是少数几个跨多领域(Solutions Architect、ConnectedSystem、Microsoft Integration和ASP.NET/IIS)的MVP之一。
致谢
本书得以出版,需要感谢本书的编辑张春雨和刘舫,他们的专业水准和责任心为本书提供了质量保证,多次合作产生的默契让我对下次合作充满期待。此外,最需要感谢的是我的妻子徐妍妍,只有我知道她在本书提交给出版社之前所做的校对工作有多么重要。
本书支持
本书针对最新版本的ASP.NET Web API,同时涉及太多底层实现的内容,所以大部分内容是找不到任何现成参考资料的,这些内容大都来自于作者对源码的分析和试验的证明。本书的最初版本是根据ASP.NET MVC Web API 2 Beta撰写的,后来微软发布了正式版,然后作者根据正式版对原来的内容进行了大量改动。这些因素加上作者自身能力的限制,都可能造成一些无法避免的错误或者偏差,如果读者在阅读过程中发现了任何问题,希望能够反馈给我。如果读者遇到任何ASP.NET MVC、ASP.NET Web API或者WCF的问题,也欢迎与我通过以下方式进行交流。
作者博客:http://www.cnblogs.com/artech
作者微博:http://www.weibo.com/artech
电子邮箱:jiangjinnan@gmail.com
微信公众账号:Artech2981
本书的每一章节都会提供一系列实例演示,读者可以根据编号(如S101、S202 等)从下载的源代码压缩包中找到对应的实例。本书的附录列出了可供下载的所有实例演示的列表和相关描述。源代码的下载地址为:www.broadview.com.cn。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。