本项目实现了ASP.NET WebApi 接口文档的自动生成功能。

微软出的ASP.NET WebApi Help Page固然好用,但是我们项目基于Owin 平台的纯WebApi 项目,不想引入MVC 的依赖,因此我们需要定制下ASP.NET WebApi Help Page。

首先来个学生习作版本:

var info = typeof(AccountController);
var sb = new StringBuilder();
var methods = info.GetMethods(BindingFlags.Public | BindingFlags.Instance | BindingFlags.DeclaredOnly);
foreach (var m in methods)
{
    sb.AppendLine(m.Name);
    var pi = m.GetParameters();
    //Get Http Method
    var postAtts = m.GetCustomAttributes(typeof(HttpPostAttribute), false);
    if (postAtts.Count() != 0)
    {
        sb.AppendLine("POST");
    }
    else
    {
        sb.AppendLine("GET");
    }
    //Get Route
    var routeAtts = m.GetCustomAttributes(typeof(RouteAttribute), false);
    if (postAtts.Count() != 0)
    {
        var routeTemp = (RouteAttribute)routeAtts[0];
        sb.AppendLine(routeTemp.Template);
    }

    //Get parameter
    foreach (ParameterInfo t in pi)
    {
        var tt = t.ParameterType;

        if (tt == typeof(string))
        {
            sb.AppendLine("Query String : " + t.Name + "={string}");
        }
        else if (tt == typeof(Guid))
        {
            sb.AppendLine("Query String Or URL : " + t.Name + "={guid}");
        }
        else if (tt.BaseType == typeof(Enum))
        {
            sb.AppendLine("Query String : " + t.Name + "={Enum}");
        }
        else if (tt.BaseType == typeof(object))
        {
            var paramter = Activator.CreateInstance(tt);
            var json = JsonHelper.ToJsonString(paramter);
            json = json.Replace("null", "\"string\"");
            sb.AppendLine(json);
        }
    }
    sb.AppendLine();
}

var result = sb.ToString();

这种东西只能写作业的时候随便写写,用到项目中还是差点火候的。我们接下去进入正题。帮助页面必然分为一个Index, 一个Detail。Index 页面需要获取所有的Controller 以及下面的Action。研究了下代码,发现系统以及给我们封装好了对应的方法,直接调用即可。

 [HttpGet]
    [Route("api/Helps")]
    public HttpResponseMessage Index()
    {
        var descriptions = Configuration.Services.GetApiExplorer().ApiDescriptions;
        var groups = descriptions.ToLookup(api => api.ActionDescriptor.ControllerDescriptor);

        StringBuilder html = GetHtmlFromDescriptionGroup(groups);
        var response = this.Request.CreateResponse();
        response.Content = new StringContent(html.ToString(), Encoding.UTF8, "text/HTML");

        return response;
    }

由于是纯API的,返回的HTML就不用什么模板了,直接拼接字符串搞定。

Index 向Detail 跳转,这里有一个有意思的方法:

 public static string GetFriendlyId(this ApiDescription description)
    {
        string path = description.RelativePath;
        string[] urlParts = path.Split('?');
        string localPath = urlParts[0];
        string queryKeyString = null;
        if (urlParts.Length > 1)
        {
            string query = urlParts[1];
            string[] queryKeys = HttpUtility.ParseQueryString(query).AllKeys;
            queryKeyString = String.Join("_", queryKeys);
        }

        StringBuilder friendlyPath = new StringBuilder();
        friendlyPath.AppendFormat("{0}-{1}",
            description.HttpMethod.Method,
            localPath.Replace("/", "-").Replace("{", String.Empty).Replace("}", String.Empty));
        if (queryKeyString != null)
        {
            friendlyPath.AppendFormat("_{0}", queryKeyString.Replace('.', '-'));
        }
        return friendlyPath.ToString();
    }

然后在详情界面里解析出我们需要的参数,以及自动生成sample

      [HttpGet]
    [Route("api/Helps/Detail")]
    public HttpResponseMessage Detail(string apiId)
    {
        var apiModel = Configuration.GetHelpPageApiModel(apiId);
        var html = GetHtmlFromApiModel(apiModel);

        var response = this.Request.CreateResponse();
        response.Content = new StringContent(html.ToString(), Encoding.UTF8, "text/HTML");

        return response;
    }

大概耗时3个hour,最后发现基本上是直接搬运了代码,用StringBuilder 代替了view 部分就完成了我们想要的功能,一种搬砖的感觉油然而生,这样的感觉不好。

ASP.NET WebApi Document Helper的更多相关文章

  1. OData – the best way to REST–实例讲解ASP.NET WebAPI OData (V4) Service & Client

    一.概念介绍 1.1,什么是OData? 还是看OData官网的简单说明: An open protocol to allow the creation and consumption of quer ...

  2. 【开源】分享一个前后端分离方案-前端angularjs+requirejs+dhtmlx 后端asp.net webapi

    一.前言 半年前左右折腾了一个前后端分离的架子,这几天才想起来翻出来分享给大家.关于前后端分离这个话题大家也谈了很久了,希望我这个实践能对大家有点点帮助,演示和源码都贴在后面. 二.技术架构 这两年a ...

  3. Asp.net WebAPI 单元测试

    现在Asp.net webapi 运用的越来越多,其单元而是也越来越重要.一般软件开发都是多层结构,上层调用下层的接口,而各层的实现人员不同,一般大家都只写自己对应单元测试.对下层的依赖我们通过IOC ...

  4. Using ASP.Net WebAPI with Web Forms

    Asp.Net WebAPI is a framework for building RESTful HTTP services which can be used across a wide ran ...

  5. 前端angularjs+requirejs+dhtmlx 后端asp.net webapi

    享一个前后端分离方案源码-前端angularjs+requirejs+dhtmlx 后端asp.net webapi   一.前言 半年前左右折腾了一个前后端分离的架子,这几天才想起来翻出来分享给大家 ...

  6. ASP.NET WebAPI使用Swagger生成测试文档

    ASP.NET WebAPI使用Swagger生成测试文档 SwaggerUI是一个简单的Restful API测试和文档工具.简单.漂亮.易用(官方demo).通过读取JSON配置显示API .项目 ...

  7. ASP.NET WebAPI 测试文档 (Swagger)

    ASP.NET WebAPI使用Swagger生成测试文档 SwaggerUI是一个简单的Restful API测试和文档工具.简单.漂亮.易用(官方demo).通过读取JSON配置显示API .项目 ...

  8. [转]OData – the best way to REST–实例讲解ASP.NET WebAPI OData (V4) Service & Client

    本文转自:http://www.cnblogs.com/bluedoctor/p/4384659.html 一.概念介绍 1.1,什么是OData? 还是看OData官网的简单说明: An open ...

  9. ASP.NET WebApi 中使用swagger 构建在线帮助文档

    1 在Visual Studio 中创建一个Asp.NET  WebApi 项目,项目名:Com.App.SysApi(本例创建的是 .net 4.5 框架程序) 2  打开Nuget 包管理软件,查 ...

随机推荐

  1. Bloom Filter 概念和原理

    Bloom filter 是由 Howard Bloom 在 1970 年提出的二进制向量数据结构,它具有很好的空间和时间效率,被用来检测一个元素是不是集合中的一个成员.如果检测结果为是,该元素不一定 ...

  2. sql server2008 字符串的替换

    DECLARE @TSql VARCHAR(MAX) SET @TSql =REPLACE(@TSql,'#PrimaryKey','0'); 1,@TSql将要替换的完整字符串 2,#Primary ...

  3. java.lang.NoClassDefFoundError: [Lorg/hibernate/engine/FilterDefinition

    解决办法: 原先:<bean id="sessionFactory"class="org.springframework.orm.hibernate3.annota ...

  4. Git SourceTree 冲突解决方案

    Git现在越来越火,很多人都从Svn迁移到Git上面,Git让我们更加与世界接轨,不再是"局域网"的程序猿,特别是掌握了Git之后,会发现它真的很好用,本文对Git中比较烦人的冲突 ...

  5. [转]Java 征途:行者的地图

    前段时间应因缘梳理了下自己的 Java 知识体系, 成文一篇望能帮到即将走进或正在 Java 世界跋涉的程序员们. 第一张,基础图 大约在 2003 年我开始知道 Java 的(当时还在用 Delph ...

  6. Delete a node from BST

    Given a root node reference of a BST and a key, delete the node with the given key in the BST. Retur ...

  7. 【Unity3D】计算二维向量夹角(-180到180)

    在Unity3D中,有时候我们需要计算二维向量的夹角.二维向量夹角一般在0~180度之前,可以直接调用Vector2.Angle(Vector2 from, Vector2 to)来计算. 但是在有些 ...

  8. UIImage 在某些控件上被放大问题

    今天用到了UISlider,想利用slider.setThumbImage(UIImage(named:"aaa"), forState: UIControlState.Norma ...

  9. 小项目特供 贪吃蛇游戏(基于C语言)

    C语言写贪吃蛇本来是打算去年暑假写的,结果因为ACM集训给耽搁了,因此借寒假的两天功夫写了这个贪吃蛇小项目,顺带把C语言重温了一次. 是发表博客的前一天开始写的,一共写了三个版本,第一天写了第一版,第 ...

  10. ePass1000 Full ActiveX Control Reference Manual Version 2.0

    ePass1000 Full ActiveX Control Reference Manual Version 2.0 Error Code Value Return Status Descripti ...