.Net Core WebApi集成swagger以及配置跨域

本文内容:

1..Net Core WebApi使用

2.集成swagger,以及开启接口注释(以及开启权限认证说明)

3.跨域问题

 

一、创建webapi

直接新建项目,选择.Net Core Web项目,然后选择WebApi模板点击确定就可以了

说明一下,配置路由时,可以配置restful风格,也可以常规请求风格:

 

有一点需要说明:

如果api的接收参数是FromBody的,那么前端在传递参数时要这样传参:

 

二、集成swagger

1.通过nuget安装swagger:

Install-Package Swashbuckle.AspNetCore

 

2.在startup文件中配置swagger:

a.在ConfigureServices方法中配置:

#region 配置swagger

            services.AddSwaggerGen(c =>
            {
                c.SwaggerDoc("v1", new Info
                {
                    //这些信息都会显示在swagger页面
                    Version = "v1.0.0",
                    Title = "Lingbug WebApi",
                    Description = "Ling、bug的.Net Core WebApi",
                    TermsOfService = "None",
                    Contact = new Contact { Name = "Ling、bug", Email = "15871739618@163.com", Url = "https://blog.csdn.net/m0_37886901" }
                });
                //在swagger中开启Auth,除了Type必须为apiKey,其他都可以自行编写
                c.AddSecurityDefinition("身份认证与授权 - Bearer", new ApiKeyScheme
                {
                    Description = "在请求该文档中的Api时,在ajax的请求头中带上token,Example:headers:{ Authorization:Bearer {token} }",
                    Name = "Authorization",
                    In = "headers",
                    Type = "apiKey"
                });
                //开启xml文档注释
                var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml";
                //小知识点:获取程序根目录AppDomain.CurrentDomain.BaseDirectory和AppContext.BaseDirectory是等价的
                var basePath = AppContext.BaseDirectory;//AppDomain.CurrentDomain.BaseDirectory;
                var xmlPath = Path.Combine(basePath, xmlFile);
                c.IncludeXmlComments(xmlPath);
            });

            #endregion

 

b.在Configure方法中也要配置:

app.UseSwagger();
            app.UseSwaggerUI(c =>
            {
                c.SwaggerEndpoint("/swagger/v1/swagger.json", "ApiHelp V1");
            });

 

c.右键项目->属性->生成:勾选XML文档文件(路径不用管,默认就好)

 

ok了,然后运行api项目,修改地址:在ip和端口后面加上/swagger,如我的:http://localhost:12151/swagger

 

三、跨域问题

我们使用WebApi一般都是用于前后端分离中,这样客户端或者在请求时,肯定会遇到跨域的问题,如何解决这个问题呢?

第一种:在前端ajax请求时,增加选项:

dataType:JSONP

crossDomain:true

 

第二种,也是我推荐的一种:在后端开启跨域

在Asp.Net WebApi中,我们需要跨域,是在web.config文件中配置,在.Net Core中我们可以直接在startup中开启和配置跨域即可:

a.配置跨域:

b.开启跨域:

 

开启和配置了跨域,接下来就是使用了,我们在api接口中,可以通过特性来标记是否可以跨域请求,标记在action上说明方法可以跨域请求到,标记在controller上,该controller上的所有方法都可以被跨域请求到

 

Ending~

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值