(三)ASP.NET core 使用Swagger

一、 为什么使用swagger

swagger是一种API文档管理的框架

1.可以在代码中添加注释,且自动生成API文档,无需再次编写,友好的界面让API文档更易懂。

2.一站式服务,只需要访问swagger的地址,就可以看到所有的后台接口和功能,并且能测试接口状态,真正是彻底的前后端分离了。

3.内嵌调试,可以查看接口状态和返回值结果很方便。

思考:如果能在把请求日志也集成进去就更好了。

二 、开始一步一步搭建swagger

第一步:创建一个.NET CORE的web项目(这么简单的事情,跳过,我用的API项目,我不晓得MVC项目可以不)

第二步:使用Swagger ,安装Nuget包。

第三步:接下来就是需要到 Startup.cs 类 

 第四步:找到ConfigureServices 注册swagger服务

 代码复制:

var ApiName = "Webapi.Core";
services.AddSwaggerGen(c =>
{
     c.SwaggerDoc("V1", new OpenApiInfo
     {
         // {ApiName} 定义成全局变量,方便修改
         Version = "V1",
         Title = $"{ApiName} 接口文档——Netcore 3.0",
         Description = $"{ApiName} HTTP API V1",

      });
      c.OrderActionsBy(o => o.RelativePath);
});

第五步:接着在StartUp类中找到Configure方法编辑,这里面RoutePrefix 就是你需要访问的url路径后面的路由比如 我们访问 localhost:8080/ApiDoc就可以跳转到Swagger的页面

代码复制:

app.UseSwagger();

app.UseSwaggerUI(c =>
{
    c.SwaggerEndpoint($"/swagger/V1/swagger.json","WebApi.Core V1");
    c.RoutePrefix = "ApiDoc";
});

 第六步:把IIS 启动的注释,项目启动的Url改成根目录

这里比较离谱,我在哔哩哔哩上找到那个视频教程,都没有这一步,然后一直都是报错,最后还是一位大神帮我解决的。

 第八步:接下来我们输入/ApiDoc敲回车,就可以了

三、 搭建swagger(前面搭建完成后的一下小修改)

这个也是我学完前面的那种方法再重新搭的,我要不说废话,上代码。

前面几步,引用Nuget包这些都是一样的

这里主要修改的是 注册swagger服务的代码。

services.AddSwaggerGen(c =>
{
    c.SwaggerDoc("V1", new OpenApiInfo
    {
        Title = "Dome.WebAPI",
        Description = "宝剑锋从磨砺出,梅花香自苦寒来。",
        Contact = new OpenApiContact()
        {
            Name = "作者:小帆",
            Email = "@qq.com"
        },
         Version = "V1",
    });
    // 开启接口注释
    var xmlPath = Path.Combine(AppContext.BaseDirectory, "Dome.WebApi.xml");
    c.IncludeXmlComments(xmlPath, true);
});

swagger服务的代码改了,那么启用Swagger组件代码也得改一下。

其实说也没改多少,UseSwaggerUI里面的东西改了一点

app.UseSwagger();
app.UseSwaggerUI(c =>
{
    c.SwaggerEndpoint($"/swagger/V1/swagger.json", "WebApi.Core V1");
});

然后项目启动的Url可以改成这样(改成这样的话,可以直接启动,就不什么/ApiDoc)

 修改项目属性(这里不想写了,找到这个页面,然后勾选一下,会生成一个绝对路径,改成虚拟的就行了。这个页面怎么找?自己慢慢找)

最后运行就可以 !!!!

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在IIS上部署ASP.NET Core Web API项目及Swagger可以按照以下步骤进行: 1. 首先,我们需要确保已经在本地系统上安装了ASP.NET Core Runtime和ASP.NET Core Hosting Bundle,以便在IIS中运行ASP.NET Core应用程序。 2. 在Visual Studio中,打开你的ASP.NET Core Web API项目。确保项目已经设置为IIS Express作为本地开发服务器。 3. 在项目根目录下的`Properties`文件夹中找到`launchsettings.json`文件,检查并确保该文件中已经配置了`applicationUrl`为`http://localhost:{port}/`,其中`port`为你希望的端口号。 4. 在Visual Studio的顶部菜单中,找到 `Build` -> `Publish {YourProjectName}`,选择发布目标为`Folder`,点击 `Publish`。 5. 在弹出的窗口中选择一个输出文件夹,用于存储发布项目的文件。 6. 打开发布文件夹,在该文件夹中应该有一个名为`web.config`的文件。双击打开该文件,确保其中有以下代码片段: ```xml <aspNetCore processPath="dotnet" arguments=".\{YourProjectName}.dll" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" forwardWindowsAuthToken="false" /> ``` 7. 打开IIS管理器,右键点击`Sites`节点,选择`Add Website`。填写网站名称以及物理路径为刚刚发布项目的目录。 8. 对于应用程序池,选择一个合适的.NET CLR版本和托管管道模式(例如:.NET CLR版本为No Managed Code,托管管道模式为集成)。 9. 在网站的右侧,找到`Authentication`,禁用匿名身份验证并启用Windows身份验证。 10. 重新启动IIS。 11. 现在,我们可以在浏览器中访问`http://localhost:{port}`,应该能够看到你的ASP.NET Core Web API已经在IIS上成功部署。 12. 最后,要在部署的项目中添加Swagger,可以通过NuGet包管理器,添加`Swashbuckle.AspNetCore`包。 13. 在`Startup.cs`文件的`ConfigureServices`方法中,添加以下配置: ```csharp services.AddSwaggerGen(c => { c.SwaggerDoc("v1", new OpenApiInfo { Title = "API", Version = "v1" }); }); ``` 14. 在`Startup.cs`文件的`Configure`方法中,添加以下代码: ```csharp app.UseSwagger(); app.UseSwaggerUI(c => { c.SwaggerEndpoint("/swagger/v1/swagger.json", "API v1"); }); ``` 15. 重新发布并重新启动IIS,现在你的ASP.NET Core Web API应该在IIS上部署并且通过Swagger可以浏览和调用你的API接口。 以上就是在IIS上部署ASP.NET Core Web API项目及Swagger的步骤。请注意,确保按照正确的顺序执行每一步,并根据自己的项目配置进行调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值