1. 新建.netCore WebApi 项目(选择Angular)。按照上一篇的加上Swage 文档,使http://localhost:11934/swagger/v1/swagger.json 可以访问。

2.新建 一个文件夹nswag,里面有3个文件

  1. refresh.bat   :  "..\node_modules\.bin\nswag" run
  2. service.config.nswag,注意修改地址
    {
    "runtime": "Default",
    "swaggerGenerator": {
    "fromSwagger": {
    "url": "http://localhost:11934/swagger/v1/swagger.json",
    "output": null
    }
    },
    "codeGenerators": {
    "swaggerToTypeScriptClient": {
    "className": "{controller}ServiceProxy",
    "moduleName": "",
    "namespace": "",
    "typeScriptVersion": 2.0,
    "template": "Angular",
    "promiseType": "Promise",
    "httpClass": "HttpClient",
    "useSingletonProvider": false,
    "injectionTokenType": "InjectionToken",
    "rxJsVersion": 6.0,
    "dateTimeType": "OffsetMomentJS",
    "nullValue": "Undefined",
    "generateClientClasses": true,
    "generateClientInterfaces": false,
    "generateOptionalParameters": false,
    "wrapDtoExceptions": false,
    "wrapResponses": false,
    "generateResponseClasses": true,
    "responseClass": "SwaggerResponse",
    "useTransformOptionsMethod": false,
    "useTransformResultMethod": false,
    "generateDtoTypes": true,
    "operationGenerationMode": "MultipleClientsFromPathSegments",
    "markOptionalProperties": false,
    "generateCloneMethod": true,
    "typeStyle": "Class",
    "extensionCode": "service.extensions.ts",
    "generateDefaultValues": true,
    "excludedTypeNames": [],
    "handleReferences": false,
    "generateConstructorInterface": true,
    "convertConstructorInterfaceData": false,
    "importRequiredTypes": true,
    "useGetBaseUrlMethod": false,
    "baseUrlTokenName": "API_BASE_URL",
    "queryNullValue": "",
    "output": "../src/shared/service-proxies/service-proxies.ts"
    },
    "swaggerToCSharpClient": {
    "generateClientClasses": true,
    "generateClientInterfaces": false,
    "generateDtoTypes": true,
    "injectHttpClient": false,
    "disposeHttpClient": true,
    "generateExceptionClasses": true,
    "exceptionClass": "SwaggerException",
    "wrapDtoExceptions": true,
    "useHttpClientCreationMethod": false,
    "httpClientType": "System.Net.Http.HttpClient",
    "useHttpRequestMessageCreationMethod": false,
    "useBaseUrl": true,
    "generateBaseUrlProperty": true,
    "generateSyncMethods": false,
    "exposeJsonSerializerSettings": false,
    "clientClassAccessModifier": "public",
    "typeAccessModifier": "public",
    "generateContractsOutput": false,
    "parameterDateTimeFormat": "s",
    "generateUpdateJsonSerializerSettingsMethod": true,
    "serializeTypeInformation": false,
    "queryNullValue": "",
    "className": "{controller}Client",
    "operationGenerationMode": "MultipleClientsFromOperationId",
    "generateOptionalParameters": false,
    "generateJsonMethods": true,
    "parameterArrayType": "System.Collections.Generic.IEnumerable",
    "parameterDictionaryType": "System.Collections.Generic.IDictionary",
    "responseArrayType": "System.Collections.ObjectModel.ObservableCollection",
    "responseDictionaryType": "System.Collections.Generic.Dictionary",
    "wrapResponses": false,
    "generateResponseClasses": true,
    "responseClass": "SwaggerResponse",
    "namespace": "MyNamespace",
    "requiredPropertiesMustBeDefined": true,
    "dateType": "System.DateTime",
    "dateTimeType": "System.DateTime",
    "timeType": "System.TimeSpan",
    "timeSpanType": "System.TimeSpan",
    "arrayType": "System.Collections.ObjectModel.ObservableCollection",
    "dictionaryType": "System.Collections.Generic.Dictionary",
    "arrayBaseType": "System.Collections.ObjectModel.ObservableCollection",
    "dictionaryBaseType": "System.Collections.Generic.Dictionary",
    "classStyle": "Inpc",
    "generateDefaultValues": true,
    "generateDataAnnotations": true,
    "excludedTypeNames": [],
    "handleReferences": false,
    "generateImmutableArrayProperties": false,
    "generateImmutableDictionaryProperties": false,
    "output": null
    },
    "swaggerToCSharpController": {
    "controllerStyle": "Partial",
    "useCancellationToken": false,
    "aspNetNamespace": "System.Web.Http",
    "className": "{controller}",
    "operationGenerationMode": "MultipleClientsFromOperationId",
    "additionalNamespaceUsages": [
    "System.Web.Http"
    ],
    "generateOptionalParameters": false,
    "generateJsonMethods": true,
    "parameterArrayType": "System.Collections.Generic.IEnumerable",
    "parameterDictionaryType": "System.Collections.Generic.IDictionary",
    "responseArrayType": "System.Collections.ObjectModel.ObservableCollection",
    "responseDictionaryType": "System.Collections.Generic.Dictionary",
    "wrapResponses": false,
    "generateResponseClasses": true,
    "responseClass": "SwaggerResponse",
    "namespace": "MyNamespace",
    "requiredPropertiesMustBeDefined": true,
    "dateType": "System.DateTime",
    "dateTimeType": "System.DateTime",
    "timeType": "System.TimeSpan",
    "timeSpanType": "System.TimeSpan",
    "arrayType": "System.Collections.Generic.IEnumerable",
    "dictionaryType": "System.Collections.Generic.Dictionary",
    "arrayBaseType": "System.Collections.ObjectModel.ObservableCollection",
    "dictionaryBaseType": "System.Collections.Generic.Dictionary",
    "classStyle": "Inpc",
    "generateDefaultValues": true,
    "generateDataAnnotations": true,
    "excludedTypeNames": [],
    "handleReferences": false,
    "generateImmutableArrayProperties": false,
    "generateImmutableDictionaryProperties": false,
    "output": null
    }
    }
    }
  3. service.extensions.ts :import 'rxjs/add/operator/finally';

3.在package.json 中添加  "nswag": "^11.18.6"

执行  npm install .如果安装不上,可以改变下仓库:npm set registry https://registry.npm.taobao.org/  参考这里

4. 运行后端。

双击运行nswag 下的refresh.bat  就可以生成 service-proxies.ts

5.原理跟踪:

  • .\node_modules\.bin\nswag 如下;

    @IF EXIST "%~dp0\node.exe" (
    "%~dp0\node.exe" "%~dp0\..\nswag\bin\nswag.js" %*
    ) ELSE (
    @SETLOCAL
    @SET PATHEXT=%PATHEXT:;.JS;=;%
    node "%~dp0\..\nswag\bin\nswag.js" %*
    )
  • nswag.js:
    #!/usr/bin/env node
    "use strict"; var defaultCoreVersion = "";
    var supportedCoreVersions = ["", "", "", ""]; // Initialize
    process.title = 'nswag';
    console.log("NSwag NPM CLI");
    var args = process.argv.splice(, process.argv.length - ).map(function (a) { return a.indexOf(" ") === - ? a : '"' + a + '"' }).join(" "); // Legacy support
    args = args.replace("--x86", "/runtime:WinX86");
    args = args.replace("/runtime:x86", "/runtime:WinX86");
    args = args.replace("--core 1.0", "/runtime:NetCore10");
    args = args.replace("--core 1.1", "/runtime:NetCore11");
    args = args.replace("--core 2.0", "/runtime:NetCore20");
    args = args.replace("--core 2.1", "/runtime:NetCore21");
    args = args.replace("--core", "/runtime:NetCore" + defaultCoreVersion); // Search for full .NET installation
    var hasFullDotNet = false;
    var fs = require('fs');
    if (process.env["windir"]) {
    try {
    var stats = fs.lstatSync(process.env["windir"] + '/Microsoft.NET');
    if (stats.isDirectory())
    hasFullDotNet = true;
    }
    catch (e) {
    console.log(e);
    }
    } var c = require('child_process');
    if (hasFullDotNet && args.toLowerCase().indexOf("/runtime:netcore") == -) {
    // Run full .NET version
    if (args.toLowerCase().indexOf("/runtime:winx86") != -) {
    var cmd = '"' + __dirname + '/binaries/Win/nswag.x86.exe" ' + args;
    var code = c.execSync(cmd, { stdio: [, , ] });
    } else {
    var cmd = '"' + __dirname + '/binaries/Win/nswag.exe" ' + args;
    var code = c.execSync(cmd, { stdio: [, , ] });
    }
    } else {
    // Run .NET Core version
    var defaultCmd = 'dotnet "' + __dirname + '/binaries/NetCore' + defaultCoreVersion + '/dotnet-nswag.dll" ' + args;
    var infoCmd = "dotnet --version";
    c.exec(infoCmd, (error, stdout, stderr) => {
    for (let version of supportedCoreVersions) {
    var coreCmd = 'dotnet "' + __dirname + '/binaries/NetCore' + version + '/dotnet-nswag.dll" ' + args; if (args.toLowerCase().indexOf("/runtime:netcore" + version) != -) {
    c.execSync(coreCmd, { stdio: [, , ] });
    return;
    } else {
    if (!error) {
    var coreVersion = stdout;
    if (coreVersion.indexOf(version + ".0") !== -) {
    c.execSync(coreCmd, { stdio: [, , ] });
    return;
    }
    }
    }
    }
    c.execSync(defaultCmd, { stdio: [, , ] });
    return;
    });
    }

Swagger 实践 <二>的更多相关文章

  1. ASP.NET MVC5 网站开发实践(二) Member区域–管理列表、回复及删除

    本来想接着上次把这篇写完的,没想到后来工作的一些事落下了,放假了赶紧补上. 目录: ASP.NET MVC5 网站开发实践 - 概述 ASP.NET MVC5 网站开发实践(一) - 项目框架 ASP ...

  2. ASP.NET MVC5 网站开发实践(二) Member区域–我的咨询列表及添加咨询

    上次把咨询的架构搭好了,现在分两次来完成咨询:1.用户部分,2管理部分.这次实现用户部分,包含两个功能,查看我的咨询和进行咨询. 目录: ASP.NET MVC5 网站开发实践 - 概述 ASP.NE ...

  3. ASP.NET MVC5 网站开发实践(二) Member区域 - 咨询管理的架构

    咨询.留言.投诉等功能是网站应具备的基本功能,可以加强管理员与用户的交流,在上次完成文章部分后,这次开始做Member区域的咨询功能(留言.投诉都是咨询).咨询跟文章非常相似,而且内容更少.更简单. ...

  4. ASP.NET MVC5 网站开发实践(二) Member区域 - 修改及删除文章

    上次做了显示文章列表,再实现修改和删除文章这部分内容就结束了,这次内容比较简单,由于做过了添加文章,修改文章非常类似,就是多了一个TryUpdateModel部分更新模型数据.   目录: ASP.N ...

  5. ASP.NET MVC5 网站开发实践(二) Member区域 - 全部文章列表

    显示文章列表分两块,管理员可以显示全部文章列表,一般用户只显示自己的文章列表.文章列表的显示采用easyui-datagrid.后台需要与之对应的action返回json类型数据   目录 ASP.N ...

  6. ASP.NET MVC5 网站开发实践(二) Member区域 - 添加文章

    上次把架构做好了,这次做添加文章.添加文章涉及附件的上传管理及富文本编辑器的使用,早添加文章时一并实现. 要点: 富文本编辑器采用KindEditor.功能很强大,国人开发,LGPL开源,自己人的好东 ...

  7. ASP.NET MVC5 网站开发实践(二) Member区域 - 文章管理架构

    上次把member的用户部分完成,现在开始做文章管理部分.文章部分根据涉及显示现实文章列表,发布文章,修改文章,删除文章等功能.最终的实现目标是使用权限来控制用户是否能进行相应操作,管理员权限的会显示 ...

  8. ASP.NET MVC5 网站开发实践(二) Member区域 - 用户部分(3)修改资料、修改密码

    在上一篇博客中实现了用户的注销和登录,其实代码里落了点东西,就是用户登录要更新最后一次登录时间和登录IP,这次补上.今天做修改资料和修改密码,TryUpdateModel是新用到的东西. 目录: AS ...

  9. ASP.NET MVC5 网站开发实践(二) Member区域 - 用户部分(2)用户登录、注销

    上次实现了用户注册,这次来实现用户登录,用到IAuthenticationManager的SignOut.SignIn方法和基于声明的标识.最后修改用户注册代码实现注册成功后直接登录. 目录: ASP ...

随机推荐

  1. JVM | JVM体系结构认知

    虚拟机 何为虚拟机呢?虚拟机是模拟执行某种指令集体系结构(ISA)的软件,是对操作系统和硬件的一种抽象.其软件模型如下图所示: 计算机系统的这种抽象类似于面向对象编程(OOP)中的针对接口编程泛型(或 ...

  2. Flume-Hbase-Sink针对不同版本flume与HBase的适配研究与经验总结

    https://cloud.tencent.com/developer/article/1025430 Flume-Hbase-Sink针对不同版本flume与HBase的适配研究与经验总结 mike ...

  3. android: requestLayout(), invalidate(), postInvalidate() 方法区别

    一.invalidate和postInvalidate 这两个方法都是在重绘当前控件的时候调用的.invalidate在UI线程中调用,postInvalidate在非UI线程中调用.因为androi ...

  4. linux性能监控 -CPU、Memory、IO、Network等指标的讲解

    [操作系统-linux]linux性能监控 -CPU.Memory.IO.Network等指标的讲解(转) 一.CPU 1.良好状态指标 CPU利用率:User Time <= 70%,Syst ...

  5. CentOS7下搭建Ansible自动化运维工具,集中管理服务器

    (1).Ansible具有如下特点: 部署简单,只需在主控端部署Ansible环境,被控端无需做任何操作: 默认使用SSH协议对设备进行管理: 主从集中化管理: 配置简单.功能强大.扩展性强: 支持A ...

  6. Spring Boot使用过滤器Filter

    首先创建一个测试用的controller:TestController: package com.zifeiy.test.controller; import org.springframework. ...

  7. Java读取Excel文件(包括xls和xlsx)的样例程序

    样例程序如下所示,其中: parseXls()函数依赖于jxl,只能读取xls格式文件: parseExcel()函数依赖于apache poi,能够读取xls和xlsx两种格式的文件. jxl的依赖 ...

  8. DB2学习笔记备忘 2018.5.9

    DB2安装的时候选择了和系统用户一致的选项,然后登陆的时候,连接的时候输入的就是计算机用户的用户名和密码. 1.3 DB2数据库体系结构 系统 一个系统表示DB2的一个安装.在一个由很多及其组成的网络 ...

  9. QuickText for Notepad++

    昨刚投入新欢Notepad++,思路如泉涌,码代码也不累了,一口气用她码了两篇文- 今再接再厉,继续.QuickText严格说来算不上什么神器级插件,也仅只是一个缩写快捷输入的插件而已.可用得好,那效 ...

  10. from表单上提交的数据都去了哪里呢?

    from表单上提交的数据都去了哪里呢? 一个简单的from案例如下: <form> 姓名:<br> <input type="text" name=& ...