自定义 Swagger Index 静态页模板

有时候我们为了在页面上增加一些小东西,比如说一个图片或者说,修改部分css样式,甚至更改 js 事件,那我们就必须修改 index.html 页面,很简单:

 

1、首先我们在 api 根目录下边创建一个 index.html 页面

 

<!--<script async="async" id="mini-profiler" src="/profiler/includes.min.js?v=4.1.0+c940f0f28d"

        data-version="4.1.0+c940f0f28d" data-path="/profiler/"

        data-current-id="" data-ids="" data-position="Left"

        data-authorized="true" data-max-traces="15" data-toggle-shortcut="Alt+P"

        data-trivial-milliseconds="2.0" data-ignored-duplicate-execute-types="Open,OpenAsync,Close,CloseAsync">

</script>-->

 

<!--1、版本号要与nuget包一致;2、id不能为空-->

<script async="async" id="mini-profiler" src="/profiler/includes.min.js?v=4.1.0+c940f0f28d"

        data-version="4.1.0+c940f0f28d" data-path="/profiler/"

        data-current-id="4ec7c742-49d4-4eaf-8281-3c1e0efa8888" data-ids="4ec7c742-49d4-4eaf-8281-3c1e0efa8888"

        data-position="Left"

        data-authorized="true" data-max-traces="5" data-toggle-shortcut="Alt+P"

        data-trivial-milliseconds="2.0" data-ignored-duplicate-execute-types="Open,OpenAsync,Close,CloseAsync">

</script>

 

<!-- HTML for static distribution bundle build -->

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>%(DocumentTitle)</title>

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <link href="https://fonts.googleapis.com/css?family=Open+Sans:400,700|Source+Code+Pro:300,600|Titillium+Web:400,600,700" rel="stylesheet">

    <link rel="stylesheet" type="text/css" href="./swagger-ui.css">

    <link rel="icon" type="image/png" href="./logo/favicon-32x32.png" sizes="32x32" />

    <script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>

    <style>

 

        html {

            box-sizing: border-box;

            overflow: -moz-scrollbars-vertical;

            overflow-y: scroll;

        }

 

        *,

        *:before,

        *:after {

            box-sizing: inherit;

        }

 

        body {

            margin: 0;

            background: #fafafa;

        }

 

        .qqgroup {

            float: right;

        }

 

        .info {

            float: left;

        }

 

        .download-contents {

            display: none;

        }

    </style>

    %(HeadContent)

</head>

<body>

    <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="position:absolute;width:0;height:0">

        <defs>

            <symbol viewBox="0 0 20 20" id="unlocked">

                <path d="M15.8 8H14V5.6C14 2.703 12.665 1 10 1 7.334 1 6 2.703 6 5.6V6h2v-.801C8 3.754 8.797 3 10 3c1.203 0 2 .754 2 2.199V8H4c-.553 0-1 .646-1 1.199V17c0 .549.428 1.139.951 1.307l1.197.387C5.672 18.861 6.55 19 7.1 19h5.8c.549 0 1.428-.139 1.951-.307l1.196-.387c.524-.167.953-.757.953-1.306V9.199C17 8.646 16.352 8 15.8 8z"></path>

            </symbol>

            <symbol viewBox="0 0 20 20" id="locked">

                <path d="M15.8 8H14V5.6C14 2.703 12.665 1 10 1 7.334 1 6 2.703 6 5.6V8H4c-.553 0-1 .646-1 1.199V17c0 .549.428 1.139.951 1.307l1.197.387C5.672 18.861 6.55 19 7.1 19h5.8c.549 0 1.428-.139 1.951-.307l1.196-.387c.524-.167.953-.757.953-1.306V9.199C17 8.646 16.352 8 15.8 8zM12 8H8V5.199C8 3.754 8.797 3 10 3c1.203 0 2 .754 2 2.199V8z" />

            </symbol>

            <symbol viewBox="0 0 20 20" id="close">

                <path d="M14.348 14.849c-.469.469-1.229.469-1.697 0L10 11.819l-2.651 3.029c-.469.469-1.229.469-1.697 0-.469-.469-.469-1.229 0-1.697l2.758-3.15-2.759-3.152c-.469-.469-.469-1.228 0-1.697.469-.469 1.228-.469 1.697 0L10 8.183l2.651-3.031c.469-.469 1.228-.469 1.697 0 .469.469.469 1.229 0 1.697l-2.758 3.152 2.758 3.15c.469.469.469 1.229 0 1.698z" />

            </symbol>

            <symbol viewBox="0 0 20 20" id="large-arrow">

                <path d="M13.25 10L6.109 2.58c-.268-.27-.268-.707 0-.979.268-.27.701-.27.969 0l7.83 7.908c.268.271.268.709 0 .979l-7.83 7.908c-.268.271-.701.27-.969 0-.268-.269-.268-.707 0-.979L13.25 10z" />

            </symbol>

            <symbol viewBox="0 0 20 20" id="large-arrow-down">

                <path d="M17.418 6.109c.272-.268.709-.268.979 0s.271.701 0 .969l-7.908 7.83c-.27.268-.707.268-.979 0l-7.908-7.83c-.27-.268-.27-.701 0-.969.271-.268.709-.268.979 0L10 13.25l7.418-7.141z" />

            </symbol>

 

            <symbol viewBox="0 0 24 24" id="jump-to">

                <path d="M19 7v4H5.83l3.58-3.59L8 6l-6 6 6 6 1.41-1.41L5.83 13H21V7z" />

            </symbol>

            <symbol viewBox="0 0 24 24" id="expand">

                <path d="M10 18h4v-2h-4v2zM3 6v2h18V6H3zm3 7h12v-2H6v2z" />

            </symbol>

        </defs>

    </svg>

    <div id="swagger-ui"></div>

    <!-- Workaround for https://github.com/swagger-api/swagger-editor/issues/1371 -->

    <script>

        if (window.navigator.userAgent.indexOf("Edge") > -1) {

            console.log("Removing native Edge fetch in favor of swagger-ui's polyfill")

            window.fetch = undefined;

        }

    </script>

    <script src="./swagger-ui-bundle.js"></script>

    <script src="./swagger-ui-standalone-preset.js"></script>

    <script>

        var int = null;

        window.onload = function () {

            var configObject = JSON.parse('%(ConfigObject)');

            var oauthConfigObject = JSON.parse('%(OAuthConfigObject)');

 

            // Apply mandatory parameters

            configObject.dom_id = "#swagger-ui";

            configObject.presets = [SwaggerUIBundle.presets.apis, SwaggerUIStandalonePreset];

            configObject.layout = "StandaloneLayout";

 

            // If oauth2RedirectUrl isn't specified, use the built-in default

            if (!configObject.hasOwnProperty("oauth2RedirectUrl"))

                configObject.oauth2RedirectUrl = window.location.href.replace("index.html", "oauth2-redirect.html");

 

            // Build a system

            const ui = SwaggerUIBundle(configObject);

 

            // Apply OAuth config

            ui.initOAuth(oauthConfigObject);

 

 

            int = setInterval(function () {

                getData();

            }, 1000);

            $("img").attr("src", "./logo/favicon-32x32.png");

        }

        function getData() {

 

            console.log(1);

            if ($(".qqgroup").length <= 0) {

                $('.info').after("<div class='qqgroup'><img  src='http://123.206.33.109:26898/QQGroup.png' alt='QQ二维码' style='width: 200px;'></div><div style='clear: both;'></div>");

                console.log(2);

                clearInterval(int);

            }

 

        }

 

    </script>

</body>

</html>

 

2、然后我们修改中间件,替换掉 swagger 的默认首页

 

app.UseSwaggerUI(c =>

 {

     //根据版本名称倒序 遍历展示

     var ApiName = "net.core";//这里你可以从appsettings.json中获取,比如我封装了一个类Appsettings.cs,具体查看我的源代码

     var version = "v1";

     c.SwaggerEndpoint($"/swagger/{version}/swagger.json"$"{ApiName} {version}");

     

     // swagger首页,设置成我们自定义的页面,记得这个字符串的写法:解决方案名.index.html

     c.IndexStream = () => GetType().GetTypeInfo().Assembly.GetManifestResourceStream("Blog.Core.index.html");//这里是配合MiniProfiler进行性能监控的,《文章:完美基于AOP的接口性能分析》,如果你不需要,可以暂时先注释掉,不影响大局。

     c.RoutePrefix = ""//路径配置,设置为空,表示直接在根域名(localhost:8001)访问该文件,注意localhost:8001/swagger是访问不到的,去launchSettings.jsonlaunchUrl去掉,如果你想换一个路径,直接写名字即可,比如直接写c.RoutePrefix = "doc";

 });

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值