本案例主要说明如何使用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. iOS开发之Alamofire源码深度解析

    今天博客中的Alamofire源码的版本是以现在最新的3.4版本为例.上篇博客系统的对NSURLSession相关的东西进行了详细的解析,详情请看<详解NSURLSession>,为了就是 ...

  2. 第一个移动前端开源项目-dailog

    你还在为手机上没有忙碌光标而发愁吗?你还在抱怨弹出框组件要依赖zepto/jqery吗?你还在纠结是否要自己写一套还是去网上寻找成现成的UI组件吗?YouA为你轻松解决所有烦恼.YouA是我为移动前端 ...

  3. 常用 meta 整理

    <!-- 针对手持设备优化,主要是针对一些老的不识别viewport的浏览器,比如黑莓 --> <meta name="HandheldFriendly" con ...

  4. asp.net core 负载均衡集群搭建(centos7+nginx+supervisor+kestrel)

    概述 本文目的是搭建三台asp.net core 集群, 并配上 nginx做负载均衡   首先准备要运行的源码 http://pan.baidu.com/s/1c20x0bA 准备三台服务器(或则虚 ...

  5. 跟着老男孩教育学Python开发【第五篇】:模块

    递归的案例:阶乘 1*2*3*4*5*6*7- def func(num):     if num == 1:         return 1     return num * func(num - ...

  6. ASP.NET Core 性能对比评测(ASP.NET,Python,Java,NodeJS)

    前言 性能是我们日常生活中经常接触到的一个词语,更好的性能意味着能给我们带来更好的用户体检.比如我们在购买手机.显卡.CPU等的时候,可能会更加的关注于这样指标,所以本篇就来做一个性能评测. 性能也一 ...

  7. 用Taurus.MVC 做个企业站(下)

    前言: 上一篇完成了首页,这一篇就把剩下的几个功能给作了吧. 包括文章列表.文章详情和产品展示. 1:文章列表: 原来的ArticleList.aspx 1:现在的articlelist.html 除 ...

  8. Centos6.x 下安装Jexus独立版

    操作步骤: #cd /tmp #wget linuxdot.net/down/jexus-5.8.1-x64.tar.gz 注:如果有新版本,则修改为相应版本号即可. #tar -zxvf jexus ...

  9. TDD原则

    TDD 介绍 测试驱动开发,或者叫 TDD,是一个敏捷方法,通过确保在代码是先前手动编写测试用 例,用测试来驱动开发,从而翻转开发生命周期(它不只是作为一种校验工具). TDD 的原则很简单的: 只有 ...

  10. MailKit---状态更改和删除

    当我们拉取邮件列表,并展示邮件后需要打开邮件,同时标识本邮件状态为已读状态,或者我们直接删除邮件.下面介绍基本的应用. 首先了解邮件的所有枚举状态:MailKit.MessageFlags包括:(No ...