本系列文章主要记录Web API使用过程中的一些个人总结,包括创建API项目、基础配置、ApiTestClient使用与HelpPage页面的优化、Owin与OAuth的使用等。

  本节主要内容是API项目的创建和基本的配置

  Aps.net Web API是构建Restful应用程序的.net框架,关于其相关介绍文档等请访问微软的 ASP.NET Web APIs

   目录

  项目创建

  基本配置

    路由模板配置

    特性(属性)路由

    过滤器

    启动HelpPage页

    返回值格式更改(json、禁用自引用等)

    返回值日期格式

  错误与解决方案

  其它

  一、创建项目

  VS2017新建项目,选择Web下的Asp.NET Web应用程序

  

  点击“确定”后在选择API应用,如果需要单元测试项目可以勾选“添加单元测试”,会在创建API项目的同时一起创建单元测试项目

  

  点击确定,等待VS自动创建完成即可。创建完成后的项目结构基本跟Asp.NET MVC相似,但你会发现最明显的两个文件WebApiConfig.cs和ValueController.cs。

  WebApiConfig.cs在项目的App_Start目录下,只有一个Register方法,这里面包含了Web API的配置、服务、路由等信息;

  ValueController.cs在项目的Controllers目录下,是模板自带的一个Api接口示例,细心的你会发现它与MVC控制器的区别是,它继承自ApiController;

  至此,VS为我们创建好了一个带有示例的API项目,现在可以运行项目,尝试调用示例中的接口。备注:运行项目后我们可以输入localhost:端口/help,进入帮助页面查看所有的api接口列表。

  比如我们访问示例下的无参Get方法

  

  我们可以看到接口返回了一个xml结构的数据,其中包含了接口中预置的value1和value2,有细心的会发现,你不是要调用的Get么,为啥路径是api/Values而不是api/Values/Get,别着急这在接下来的配置中讲到,这属于API的路由规则配置。

  二、基本配置

  接下来对创建的api项目进行一些配置修改。

  1.路由模板格式修改(WebApiConfig文件)

  我们修改原路由配置(api/{controller}/{id})如下

  

      config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{action}",
defaults: new { id = RouteParameter.Optional }
);

  这样修改后路由的匹配规则就变成了api/控制器名/方法名,刚才我们的访问Get方法就不能使用api/Values而需要使用api/Values/Get了。当然如果你的接口是需要写在Areas下的话,可以将routTemplate改为ap/{controller}/{action},或再添加一条路由规则

  2.特性(属性)路由

  特性路由的启用是在WebApiConfig的Register方法中添加config.MapHttpAttributeRoutes();即可,默认的是启用了该配置的。

  之所以单独说一下是因为,使用特性路由的情况下WebApiConfig的注册只能使用GlobalConfiguration.Configure(WebApiConfig.Register),不能使用WebApiConfig.Register(GlobalConfiguration.Configuration)。

  属性路由也是将客户端的请求映射到对应的action上,但相对于通过模板、http方法等来设置路由更加灵活,并且一些个性的需求使用模板、管理等很难实现。参考 JIM.WEN 的web api Route属性定义

  

  3.过滤器

  Web API的过滤器主要有三种AuthorizationFilterAttribute、ActionFilterAttribute、ExceptionFilterAttribute,根据你的运用创造力可以实现很多的自定义操作(骚操作~),网上相关的使用示例讲解蛮多的,就不写了,可参考 尘嚣之上的webapi的几种过滤器。

  这里主要说一下ExceptionHandler和ExceptionLogger。为什么讲他们呢,是因为ExceptionFilterAttribute虽然可以定义全局异常处理,但是有一些异常它是不能处理的,例如:控制器构造函数的异常、消息处理程序异常、路由过程中的异常、序列化返回内容抛出的异常、其他过滤器的异常等。

  定义两个类分别继承自ExceptionHandler和ExceptionLogger:

  

    /// <summary>
/// 自定义异常处理
/// </summary>
public class CustomExceptionHandler : ExceptionHandler
{
public override void Handle(ExceptionHandlerContext context)
{
//可以处理一下统一的返回格式、自定义处理等
//content.Result
}
} /// <summary>
/// 自定义异常日志
/// </summary>
public class CustomExceptionLogger : ExceptionLogger
{
public override void Log(ExceptionLoggerContext context)
{
//可以处理下异常日志记录等
//context.Request.RequestUri--请求地址
//context.Request.Content--请求内容
//context.ExceptionContext.Exception--异常信息
}
}

  4.项目启动打开Help页

  启动API项目后,需要手动敲入/Help才能进入帮助文档页面,操作不是很友好,我们可以通过修改路由来实现启动后直接进入help页,代码如下(App_Start--RouteConfig):

  

         /// <summary>
///
/// </summary>
/// <param name="routes"></param>
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Help", action = "Index", id = UrlParameter.Optional },
namespaces: new string[] { "SampleAPI.Areas.HelpPage.Controllers" }
).DataTokens.Add("Area", "HelpPage");
}

  5.返回数据格式修改(返回json格式数据)

  在WebApiConfig的Regiter中添加以下代码,即可

  

     // Web API 配置和服务

     //清除XML格式
config.Formatters.XmlFormatter.SupportedMediaTypes.Clear();
//JSON格式
config.Formatters.Add(new JsonMediaTypeFormatter());

  再调用我们的Get方法,发现返回值已经是json格式的了

  

  返回Json数据序列化时针对返回结果的child自引用循环,我们可以设置忽略,我们这里使用的序列化插件是Newtonsoft.json,在WebApiConfig中增加如下配置

  

     var jsonFormatter = config.Formatters.OfType<JsonMediaTypeFormatter>().First();
//忽略对象的child自引用循环
config.Formatters.JsonFormatter.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore;

  6.返回结果中日期的统一格式化处理

  这里配置的是 “yyyy-MM-dd HH:mm:ss”格式,可根据自己的需要进行设置

  

   config.Formatters.JsonFormatter.SerializerSettings.Converters.Add(new IsoDateTimeConverter()
{
DateTimeFormat = "yyyy'-'MM'-'dd' 'HH':'mm':'ss"
});

  三、错误与解决方案

  1.“该对象尚未初始化。请确保在所有其他初始化代码后面的应用程序启动代码中调用 HttpConfiguration.EnsureInitialized()。”

   或 “ValueFactory 尝试访问此实例的 Value 属性。”

   原因:启用了特性路由但WebApiCofig的注册又使用了WebApiConfig.Register(GlobalConfiguration.Configuration)

   解决方案:将WebApiCofig的注册方式改为GlobalConfiguration.Configure(WebApiConfig.Register)即可

   附:两种注册方式的区别 stackoverflow

  2.WebApi所有的接口访问全部404 找不到匹配的资源

   原因:api路由注册放在了mvc路由的后边

     解决方案:将GlobalConfiguration.Configure(WebApiConfig.Register)放到RouteConfig.RegisterRoutes(RouteTable.Routes)执行之前即可,别问我为什么,我也不明白这骚操作,

Web API使用记录系列(一)创建API项目与基本配置的更多相关文章

  1. Web API使用记录系列(二)HelpPage优化与WebApiTestClient

    继续使用记录的第二节,HelpPage的优化与测试工具WebApiTestClient的使用. 之前没怎么整理博客,都是记录一下笔记,真正好好整理发现没想像的那么简单.不管怎么说还是培养下写博客的习惯 ...

  2. SpringBoot01 InteliJ IDEA安装、Maven配置、创建SpringBoot项目、属性配置、多环境配置

    1 InteliJ IDEA 安装 下载地址:点击前往 注意:需要下载专业版本的,注册码在网上随便搜一个就行啦 2 MAVEN工具的安装 2.1 获取安装包 下载地址:点击前往 2.2 安装过程 到官 ...

  3. Web API使用记录系列(三)Web API与Owin

    还好在坚持,今天继续更新第三篇随笔----使用owin来启动WebAPI(这里还是以IIS为宿主,当然也可以使用别的如Console.Windows Server等) 关于OWIN(Open Web ...

  4. Web API使用记录系列(四)OAuth授权与身份校验

    呼,开干第四篇,基于OWIN搭建OAuth认证授权服务器与接口身份校验. OAuth包含授权码模式.密码模式.客户端模式和简化模式,这里我们文章记录的是密码模式和客户端模式. 目录 引用安装 授权处理 ...

  5. Android+Jquery Mobile学习系列(3)-创建Android项目

    前两章分别对开发环境和Jquery Mobile基础知识进行了介绍,本章介绍创建一个Android项目,并使用WebView控件显示HTML数据. 首先创建一个Android Application项 ...

  6. 使用PyCharm创建Django项目及基本配置

    https://segmentfault.com/a/1190000011576316 pycharm是个很不错的python开发工具,大大缩短了python项目的创建时间以及调试时间在使用pytho ...

  7. vue cli3 创建的项目中eslint 配置 问题的解决

    1--   vue cli3 项目文件结构 2-- 注释问题 在eslintrc.js 文件中,将 '@vue/standard' 注释后重启即可: 3-- 配置 eslint 文件 在 vue-cl ...

  8. java web开发入门九(Maven使用&idea创建maven项目)基于intellig idea

    Maven 1.解决的问题 jar包的依赖和管理:版本.依赖关系等 自动构建项目 2.maven介绍 1.Maven是什么? Apache Maven是一个软件项目管理的综合工具.基于项目对象模型(P ...

  9. Nodejs express中创建ejs项目,解决express下默认创建jade,无法创建ejs问题

    最近在看<Node.js开发指南>,看到使用nodejs进行web开发的时候,准备创建ejs项目遇到问题了, 书上命令为: express -t ejs microblog 可是执行后,仍 ...

随机推荐

  1. 1003: FFF团的情侣活动--课程作业--找出N个数字中唯一出现奇数次的数

    1003: FFF团的情侣活动 Time Limit: 1 Sec  Memory Limit: 2 MB Description 圣诞节快到了,Water作为大FFF团团长,组织许多对情侣进行电影院 ...

  2. 【LOJ2254】SNOI2017一个简单的询问

    莫队,每次询问的是两个区间,就把区间拆开,分开来算就好了. 借鉴了rank1大佬的玄学排询问的姿势. #include<bits/stdc++.h> #define N 50010 typ ...

  3. BZOJ 4516: [Sdoi2016]生成魔咒——后缀数组、并查集

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4516 题意 一开始串为空,每次往串后面加一个字符,求本质不同的子串的个数,可以离线.即长度为 ...

  4. [bugfix]copy属性参数将NSMutableArray变为NSArray类型

    问题:NSMutableArray 声明为 copy 属性参数后即使接受NSMutableArray变量依然为NSArray变量 测试: 属性申明为: 1 @property (nonatomic, ...

  5. window.screen.height和window.screen.availHeight和document.body.clientHeight和document.documentElement.clientHeight

    说这几个属性前 我说一下我的设备 我的设备有两个,一个高度为1080的显示器,一个高度为800的电脑 第一种:window.screen.height 这个方法是获取用户电脑屏幕的高度,是不关浏览器或 ...

  6. LeetCode解题报告—— Combination Sum & Combination Sum II & Multiply Strings

    1. Combination Sum Given a set of candidate numbers (C) (without duplicates) and a target number (T) ...

  7. python之路——面向对象进阶

    阅读目录 isinstance和issubclass 反射 setattr delattr getattr hasattr __str__和__repr__ __del__ item系列 __geti ...

  8. 【JBPM4】获取任务

    示例代码: <?xml version="1.0" encoding="UTF-8"?> <process name="test&q ...

  9. 前端读者 | 百度前端编码规范(HTML)

    本文来自:百度FEX 1 前言 HTML 作为描述网页结构的超文本标记语言,在百度一直有着广泛的应用.本文档的目标是使 HTML 代码风格保持一致,容易被理解和被维护. 2 代码风格 2.1 缩进与换 ...

  10. cocos2dx 大地图分块加载的研究(初)

    http://blog.csdn.net/dinko321/article/details/46739563 http://blog.csdn.net/u012812482/article/detai ...