• swagger


    swaggerconfig。cs

    using System.Web.Http;
    using WebActivatorEx;
    using Lunz.Web.RiskSystem.Api;
    using Swashbuckle.Application;
    using Lunz.Web.RiskSystem.Api.App_Start;

    [assembly: PreApplicationStartMethod(typeof(SwaggerConfig), "Register")]

    namespace Lunz.Web.RiskSystem.Api
    {
    public class SwaggerConfig
    {
    public static void Register()
    {
    var thisAssembly = typeof(SwaggerConfig).Assembly;

    GlobalConfiguration.Configuration
    .EnableSwagger(c =>
    {

    c.SingleApiVersion("v1", "Lunz.Web.RiskSystem.Api");
    //c.IncludeXmlComments(GetXmlCommentsPath());
    var xmlFile = string.Format("{0}/bin/Lunz.Web.RiskSystem.Api.XML",System.AppDomain.CurrentDomain.BaseDirectory);
    if (System.IO.File.Exists(xmlFile))
    {
    c.IncludeXmlComments(xmlFile);
    }
    c.CustomProvider((defaultProvider) => new SwaggerCacheProvider(defaultProvider,xmlFile));
    c.OperationFilter<HttpAuthHeaderFilter>();

    })
    .EnableSwaggerUi(c =>
    {

    // 使用中文
    c.InjectJavaScript(thisAssembly, "Lunz.Web.RiskSystem.Api.Scripts.Swagger.swagger_lang.js");

    });
    }
    //private static string GetXmlCommentsPath()
    //{
    // return string.Format("{0}/bin/Lunz.Web.RiskSystem.Api.XML", System.AppDomain.CurrentDomain.BaseDirectory);
    //}
    }
    }

    2SwaggerCacheProvider.cs

    using Swashbuckle.Swagger;
    using System;
    using System.Collections.Concurrent;
    using System.Collections.Generic;
    using System.IO;
    using System.Linq;
    using System.Web;
    using System.Xml;

    namespace Lunz.Web.RiskSystem.Api.App_Start
    {
    /// <summary>
    /// swagger显示控制器的描述
    /// </summary>
    public class SwaggerCacheProvider : ISwaggerProvider
    {
    private readonly ISwaggerProvider _swaggerProvider;
    private static ConcurrentDictionary<string, SwaggerDocument> _cache = new ConcurrentDictionary<string, SwaggerDocument>();
    private readonly string _xml;
    /// <summary>
    ///
    /// </summary>
    /// <param name="swaggerProvider"></param>
    /// <param name="xml">xml文档路径</param>
    public SwaggerCacheProvider(ISwaggerProvider swaggerProvider, string xml)
    {
    _swaggerProvider = swaggerProvider;
    _xml = xml;
    }

    public SwaggerDocument GetSwagger(string rootUrl, string apiVersion)
    {

    var cacheKey = string.Format("{0}_{1}", rootUrl, apiVersion);
    SwaggerDocument srcDoc = null;
    //只读取一次
    if (!_cache.TryGetValue(cacheKey, out srcDoc))
    {
    srcDoc = _swaggerProvider.GetSwagger(rootUrl, apiVersion);

    srcDoc.vendorExtensions = new Dictionary<string, object> { { "ControllerDesc", GetControllerDesc() } };
    _cache.TryAdd(cacheKey, srcDoc);
    }
    return srcDoc;
    }

    /// <summary>
    /// 从API文档中读取控制器描述
    /// </summary>
    /// <returns>所有控制器描述</returns>
    public ConcurrentDictionary<string, string> GetControllerDesc()
    {
    string xmlpath = _xml;
    ConcurrentDictionary<string, string> controllerDescDict = new ConcurrentDictionary<string, string>();
    if (File.Exists(xmlpath))
    {
    XmlDocument xmldoc = new XmlDocument();
    xmldoc.Load(xmlpath);
    string type = string.Empty, path = string.Empty, controllerName = string.Empty;

    string[] arrPath;
    int length = -1, cCount = "Controller".Length;
    XmlNode summaryNode = null;
    foreach (XmlNode node in xmldoc.SelectNodes("//member"))
    {
    type = node.Attributes["name"].Value;
    if (type.StartsWith("T:"))
    {
    //控制器
    arrPath = type.Split('.');
    length = arrPath.Length;
    controllerName = arrPath[length - 1];
    if (controllerName.EndsWith("Controller"))
    {
    //获取控制器注释
    summaryNode = node.SelectSingleNode("summary");
    string key = controllerName.Remove(controllerName.Length - cCount, cCount);
    if (summaryNode != null && !string.IsNullOrEmpty(summaryNode.InnerText) && !controllerDescDict.ContainsKey(key))
    {
    controllerDescDict.TryAdd(key, summaryNode.InnerText.Trim());
    }
    }
    }
    }
    }
    return controllerDescDict;
    }
    }
    }

    3swagger_lang.js

    /// <summary>
    /// 中文转换
    /// </summary>
    var SwaggerTranslator = (function () {
    //定时执行检测是否转换成中文,最多执行500次 即500*50/1000=25s
    var iexcute = 0,
    //中文语言包
    _words = {
    "Warning: Deprecated": "警告:已过时",
    "Implementation Notes": "实现备注",
    "Response Class": "响应类",
    "Status": "状态",
    "Parameters": "参数",
    "Parameter": "参数",
    "Value": "值",
    "Description": "描述",
    "Parameter Type": "参数类型",
    "Data Type": "数据类型",
    "Response Messages": "响应消息",
    "HTTP Status Code": "HTTP状态码",
    "Reason": "原因",
    "Response Model": "响应模型",
    "Request URL": "请求URL",
    "Response Body": "响应体",
    "Response Code": "响应码",
    "Response Headers": "响应头",
    "Hide Response": "隐藏响应",
    "Headers": "头",
    "Try it out!": "试一下!",
    "Show/Hide": "显示/隐藏",
    "List Operations": "显示操作",
    "Expand Operations": "展开操作",
    "Raw": "原始",
    "can't parse JSON. Raw result": "无法解析JSON. 原始结果",
    "Model Schema": "模型架构",
    "Model": "模型",
    "apply": "应用",
    "Username": "用户名",
    "Password": "密码",
    "Terms of service": "服务条款",
    "Created by": "创建者",
    "See more at": "查看更多:",
    "Contact the developer": "联系开发者",
    "api version": "api版本",
    "Response Content Type": "响应Content Type",
    "fetching resource": "正在获取资源",
    "fetching resource list": "正在获取资源列表",
    "Explore": "浏览",
    "Show Swagger Petstore Example Apis": "显示 Swagger Petstore 示例 Apis",
    "Can't read from server. It may not have the appropriate access-control-origin settings.": "无法从服务器读取。可能没有正确设置access-control-origin。",
    "Please specify the protocol for": "请指定协议:",
    "Can't read swagger JSON from": "无法读取swagger JSON于",
    "Finished Loading Resource Information. Rendering Swagger UI": "已加载资源信息。正在渲染Swagger UI",
    "Unable to read api": "无法读取api",
    "from path": "从路径",
    "Click to set as parameter value": "点击设置参数",
    "server returned": "服务器返回"
    },

    //定时执行转换
    _translator2Cn = function () {
    if ($("#resources_container .resource").length > 0) {
    _tryTranslate();
    }

    if ($("#explore").text() == "Explore" && iexcute < 500) {
    iexcute++;
    setTimeout(_translator2Cn, 50);
    }
    },

    //设置控制器注释
    _setControllerSummary = function () {
    $.ajax({
    type: "get",
    async: true,
    url: $("#input_baseUrl").val(),
    dataType: "json",
    success: function (data) {
    var summaryDict = data.ControllerDesc;
    var id, controllerName, strSummary;
    $("#resources_container .resource").each(function (i, item) {
    id = $(item).attr("id");
    if (id) {
    controllerName = id.substring(9);
    console.log(controllerName)
    strSummary = summaryDict[controllerName];
    if (strSummary) {
    $(item).children(".heading").children(".options").prepend('<li class="controller-summary" title="' + strSummary + '">' + strSummary + '</li>');
    }
    }
    });
    }
    });
    },

    //尝试将英文转换成中文
    _tryTranslate = function () {
    $('[data-sw-translate]').each(function () {
    $(this).html(_getLangDesc($(this).html()));
    $(this).val(_getLangDesc($(this).val()));
    $(this).attr('title', _getLangDesc($(this).attr('title')));
    });
    },
    _getLangDesc = function (word) {
    return _words[$.trim(word)] !== undefined ? _words[$.trim(word)] : word;
    };

    return {
    Translator: function () {
    document.title = "API描述文档";
    $('body').append('<style type="text/css">.controller-summary{color:#10a54a !important;word-break:keep-all;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-250px;text-align:right;cursor:default;} </style>');
    $("#logo").html("接口描述").attr("href", "/Home/Index");
    //设置控制器描述
    _setControllerSummary();
    _translator2Cn();
    }
    }
    })();
    //执行转换
    SwaggerTranslator.Translator();

    4\HttpAuthHeaderFilter.cs

    using Swashbuckle.Swagger;
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Http;
    using System.Web.Http.Description;
    using System.Web.Http.Filters;

    namespace Lunz.Web.RiskSystem.Api.App_Start
    {
    /// <summary>
    /// swagger 增加 AUTH 选项
    /// </summary>
    public class HttpAuthHeaderFilter : IOperationFilter
    {
    /// <summary>
    /// 应用
    /// </summary>
    /// <param name="operation"></param>
    /// <param name="schemaRegistry"></param>
    /// <param name="apiDescription"></param>
    public void Apply(Operation operation, SchemaRegistry schemaRegistry, ApiDescription apiDescription)

    {
    if (operation.parameters == null)
    operation.parameters = new List<Parameter>();
    var filterPipeline = apiDescription.ActionDescriptor.GetFilterPipeline(); //判断是否添加权限过滤器
    var isAuthorized = filterPipeline.Select(filterInfo => filterInfo.Instance).Any(filter => filter is IAuthorizationFilter); //判断是否允许匿名方法
    var allowAnonymous = apiDescription.ActionDescriptor.GetCustomAttributes<AllowAnonymousAttribute>().Any();
    if (isAuthorized && allowAnonymous)
    {
    operation.parameters.Add(new Parameter { name = "appKey", @in = "header", description = "B77E5F2A-D5AB-4B7A-B8A8-1D57F83EE37D", required = false, type = "string" });
    operation.parameters.Add(new Parameter { name = "authToken", @in = "header", description = "authToken", required = false, type = "string" });
    }
    }
    }
    }

  • 相关阅读:
    BERT 简介 P1_李宏毅
    GAN_P4 Learning from Unpaired Data_李宏毅
    GAN_P3_李宏毅
    Generation P1_李宏毅
    GAN_P2_Theory behind GAN_李宏毅
    李宏毅_Transformer p2
    李宏毅_Transformer p1
    强类型数据集 官方教程
    网页管理系统一
    读张子阳的用户验证自定义IPrincipal和IIdentity有感
  • 原文地址:https://www.cnblogs.com/cacti/p/10039510.html
Copyright © 2020-2023  润新知