本案例主要说明如何使用NSwag 工具使用桌面工具快速生成c# 客户端代码、快速的访问Web Api。

NSwagStudio 下载地址 比较强大、可以生成TypeScript、WebApi Controller、CSharp Client

1、运行WebApi项目  URL http://yourserver/swagger 然后你将看到界面如下

1.1 Web API 代码

该代码使用的是Abp框架、如果不了解Abp框架的请到官网http://www.aspnetboilerplate.com/ 了解

  • 实休代码

       public class UserInformation : Entity<int>, IHasCreationTime, IHasModificationTime
    {
    [StringLength()]
    public string UserName { get; set; }
    public int UserAge { get; set; }
    [StringLength()]
    public string UserAddress { get; set; } public UserInformation()
    {
    CreationTime = Clock.Now;
    }
    public DateTime CreationTime { get; set; }
    public DateTime? LastModificationTime { get; set; }
    }

    实体代码

  • Application 应用

     [AutoMapTo(typeof(UserInformation))]
    public class CreateUserInformationDto : IHasCreationTime
    {
    public string UserName { get; set; }
    public int UserAge { get; set; } public string UserAddress { get; set; }
    public DateTime CreationTime { get; set; }
    public CreateUserInformationDto()
    {
    CreationTime = Clock.Now;
    }
    } public class DeleteUserInformationDto : IEntityDto
    {
    public int Id { get; set; }
    } public class GetAllUserInformationDto : PagedAndSortedResultRequestDto, ICustomValidate
    {
    public string UserName { get; set; }
    public void AddValidationErrors(CustomValidationContext context)
    {
    if (string.IsNullOrEmpty(UserName))
    {
    context.Results.Add(new ValidationResult("用户名称关键字不能为空!"));
    }
    }
    } public class GetInputUserInformatinDto : IEntityDto
    {
    public int Id { get; set; }
    } [AutoMapTo(typeof(UserInformation))]
    public class UpdateUserInformationDto : CreateUserInformationDto, IEntityDto, IHasModificationTime
    { public UpdateUserInformationDto()
    {
    LastModificationTime = Clock.Now;
    } public DateTime? LastModificationTime { get; set; }
    public int Id { get; set; }
    } public class UserInformationDto : EntityDto, IHasCreationTime, IHasModificationTime
    { public string UserName { get; set; }
    public int UserAge { get; set; } public string UserAddress { get; set; } public UserInformationDto()
    {
    CreationTime = Clock.Now;
    }
    public DateTime CreationTime { get; set; }
    public DateTime? LastModificationTime { get; set; }
    }

    Dtos

      public interface IUserAppService :
    ICrudAppService<UserInformationDto, int,
    GetAllUserInformationDto,
    CreateUserInformationDto,
    UpdateUserInformationDto,
    GetInputUserInformatinDto,
    DeleteUserInformationDto>
    { } public class UserAppService :
    CrudAppService
    <UserInformation,
    UserInformationDto, int,
    GetAllUserInformationDto,
    CreateUserInformationDto,
    UpdateUserInformationDto,
    GetInputUserInformatinDto,
    DeleteUserInformationDto>,
    IUserAppService
    {
    private ICacheManager cacheManager;
    public UserAppService(IRepository<UserInformation, int> repository,ICacheManager cache) : base(repository)
    {
    cacheManager = cache;
    } protected override IQueryable<UserInformation> CreateFilteredQuery(GetAllUserInformationDto input)
    {
    return base.CreateFilteredQuery(input).Where(o=>o.UserName.Contains(input.UserName));
    }
    }

    Application Service

  2、生成客户端代码 并且访问Web API

2.1 安装工具和创建测试客户端项目

  • 安装Install NSwagStudio
  • 创建一个新的c#客户端项目
  • 将所需的程序集依赖项添加到库项目中

2.2 生成代码

  • 启动 NSwagStudio 然后选择 Swagger Specification
  • 在Load Swagger Specification from URL: http://yourserver/swagger/v1/swagger.json  前期条件是服务必须期启动
  • 选择一个右边的选项卡 如:"CSharpClient"、然后点击“ Generate Outputs”
  • 复制生所的代码到你的客户端项目中
  • 同时也可以设置、如项目命名空间、以及配置输出文件路经、生成DTO的一些配置

  3、保存脚本

  • 保存文件.nswag 把当前的一些配置保存

4、 客户端代码实现

                  UserClient app = new UserClient();
var data = app.GetAllAsync(new GetAllUserInformationDto()
{
MaxResultCount = ,
SkipCount = ,
Sorting = "desc",
UserName = "luyong"
}); //新增数据
var app2= app.CreateAsync(new CreateUserInformationDto()
{
CreationTime = DateTime.Now,
UserAddress = "china",
UserName = "fadf333",
UserAge =
}); dataGridView1.DataSource = data.Result.Items;

NSwagStudio for Swagger Api的更多相关文章

  1. 添加swagger api文档到node服务

    swagger,一款api测试工具,详细介绍参考官网:http://swagger.io/ ,这里主要记录下怎么将swagger api应用到我们的node服务中: 1.任意新建node api项目, ...

  2. Swagger API接口管理

    介绍         Swagger API框架,用于管理项目中API接口,属当前最流行的API接口管理工具. Swagger功能强大,UI界面漂亮,支持在线测试等!         Swagger包 ...

  3. swagger api 转graphql npm 包试用

    graphql 比较方便的进行api 的查询,操作,swagger 是一个方便的open api 描述标准,当前我们有比较多的 restapi 但是转换为graphql 是有成本的,还好swagger ...

  4. swagger & api & swagger ui

    swagger & api swagger ui # run server $ swagger project start api-app # call api $ curl http://1 ...

  5. Swagger API文档集中化注册管理

    接口文档是前后端开发对接时很重要的一个组件.手动编写接口文档既费时,又存在文档不能随代码及时更新的问题,因此产生了像swagger这样的自动生成接口文档的框架.swagger文档一般是随项目代码生成与 ...

  6. xadmin引入drf-yasg生成Swagger API文档

    一.安装drf-yasg: 由于django-rest-swagger已经废弃了 所以引入了drf-yasg pip install drf-yasg 安装install drf-yasg库 http ...

  7. restful swagger api java go

    rest框架使用swagger api,接口越来越多后性能会很差,如何优化? - 知乎https://www.zhihu.com/question/59349319 golang restful 框架 ...

  8. Swagger API文档

    Swagger API文档集中化注册管理   接口文档是前后端开发对接时很重要的一个组件.手动编写接口文档既费时,又存在文档不能随代码及时更新的问题,因此产生了像swagger这样的自动生成接口文档的 ...

  9. Swagger : API JSON 文件 转 PDF 问题总结

    1.  swagger API 转 PDF 具体请参考:woshihoujinxin/swagger-gendoc 2. 问题总结 接口方法值返回值为  void 类型时, @ApiOperation ...

随机推荐

  1. [C#] C# 知识回顾 - 你真的懂异常(Exception)吗?

    你真的懂异常(Exception)吗? 目录 异常介绍 异常的特点 怎样使用异常 处理异常的 try-catch-finally 捕获异常的 Catch 块 释放资源的 Finally 块 一.异常介 ...

  2. redis集成到Springmvc中及使用实例

    redis是现在主流的缓存工具了,因为使用简单.高效且对服务器要求较小,用于大数据量下的缓存 spring也提供了对redis的支持: org.springframework.data.redis.c ...

  3. H5坦克大战之【玩家控制坦克移动2】

    周一没有看圣诞大战,这几天比较忙也没有看赛后的报道,今天就先不扯NBA,随便扯扯自己.昨天在电脑里找东西的时候翻到以前兼职健身教练时的照片,思绪一下子回到学生时代,脑子久久换不过来.现在深深觉得健身和 ...

  4. 在 Windows7 上按照 MySQL5.7

    在 Windows7 上按照 MySQL5.7 1.从官网下载最新版本的 MySQL,这里下载的是 mysql-5.7.17-win32: 2.将下载的 mysql-5.7.17-win32.zip ...

  5. 豪情-CSS解构系列之-新浪页面解构-01

    目录: 一. 新浪的布局特点 二. 内容细节的特点 三. 其中相关的一些基础技术点 1. 常见布局方法 2. 布局要点 3. Debugger误区 4.列表 5.字体颜色 6.CSS选择符 7.CSS ...

  6. html5 audio总结

    前言 html5中对音频,视频播放原生支持.最近做了一个音乐播放器,得益于快过年了,才能抽出一点时间来总结一下.总的来说,html5对audio的支持非常强大, 难怪flash要死.浏览器上装播放插件 ...

  7. Visual Studio Code 使用Git进行版本控制

    Visual Studio Code 使用Git进行版本控制 本来认为此类教程,肯定是满网飞了.今天首次使用VS Code的Git功能,翻遍了 所有中文教程,竟没有一个靠谱的.遂动笔写一篇. 请确保你 ...

  8. 最牛的打字效果JS插件 typing.js

    最新在做公司的一个项目,需要实现一个敲打代码的动画效果,粗意味比较简单,果断自己直接开写,写着写着发现是一个坑.需要支持语法高亮,并不能直接简单的用setTimeout来动态附件innerHTML.苦 ...

  9. C++右值引用浅析

    一直想试着把自己理解和学习到的右值引用相关的技术细节整理并分享出来,希望能够对感兴趣的朋友提供帮助. 右值引用是C++11标准中新增的一个特性.右值引用允许程序员可以忽略逻辑上不需要的拷贝:而且还可以 ...

  10. ABP框架 - 启动配置

    文档目录 本节内容: 配置ABP 替换内置服务 配置模块 为一个模块创建配置 ABP在启动时,提供基础框架和模型来配置和模块化. 置ABP 在预初始化事件中进行配置,示例: kid1412注:XmlL ...