- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 Swagger 的新手,据我所知,它用于自动生成 API 文档。除此之外,我认为它还可以通过使用 Swagger Codegen 来生成前端。在这一步,我对在我的项目中正确使用 swagger 感到困惑。
我已经使用 .NET Core 创建了后端,并且 API 方法已准备就绪。现在,我需要将 swagger 集成到我的项目中。我有一个初始的 Angular 前端应用程序,但由于代码是混合的,我想从 stratch 创建前端,然后将 Swagger 集成到其中。所以;
1. 我应该使用必要的 Swagger 工具生成前端吗?看起来不太好,但是如果一般使用的话,随着项目变大不会有问题,我当然可以使用这个选项。
2.如果我从stratch创建Angular项目,如何集成swagger?是否应该使用相关组件的ts文件来生成代码?
3. 如果我向前端添加一个新组件,并向已使用 Swagger 的 API 添加相应的 API 方法。我应该做哪些修改?我尝试了一下,它在构建项目后生成了一个新的 swagger 配置文件。
最佳答案
继续讨论我在问题下发表的评论。
为了澄清什么是 swagger 和 openApi,swagger 既是一个 REST API 规范(例如 swaggerSpec.Json),又是一组处理该规范的工具。例如,swagger codegen、swagger UI 等。现在在某个时间点,该规范已从 swagger 重命名为 OpenApi。
这意味着该规范称为 OpenApi,而 swagger 是一组处理 openApi 的工具。
来源:https://swagger.io/blog/api-strategy/difference-between-swagger-and-openapi/
除了 swagger 之外,还有一组替代工具(例如 NSwag 和 Swashbuckle)可以使使用 openApi 规范变得更加容易。
有两个主要部分:
我研究了所有 3 个选项(Swagger、SwashBuckle 和 NSwag),我选择了 NSwag,因为当时 a) 它是我工作的那个,b) 它具有最多的功能,c) 社区相当不错积极的。这是大约一年前的事。
我将解释我的工作流程,这应该可以回答您的大多数问题。我觉得这个问题变得相当广泛,所以请进行一些挖掘,并尝试根据您的需求找到更具体的问题。
就像我说的,我使用 NSwag 工具链:
我在服务器应用程序中创建 Asp.Net Controller 。这包含 Controller 功能/端点的一些属性,以便更好地生成 swagger 规范:
然后我使用 NSWag studio 创建一个 openApi 文档文件
Startup.cs 中的某处:
public void Configure(IApplicationBuilder app, IWebHostEnvironment env, IOptions<AppSettings> appSettingsAccessor, ILogger<Startup> logger, StaticFileConfigSection staticFileConfig)
{
// Add the openApi document and serve the swagger dashboard.
app.UseOpenApi();
app.UseSwaggerUi3(); // serve Swagger UI
...
然后我可以转到/swagger 查看 Web UI:
就是这样。当然,所有这些工具都可以自动化 - 但我选择不这样做。要让它发挥作用可能会很麻烦,而且在 NSwag studio 中我总是只需点击一下按钮即可。这迫使我对工作更加小心。
关于asp.net - 在 Angular 中使用 Swagger,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64059809/
我试图在我的微服务项目中生成一个单一的 swagger,在 Api 网关中将所有服务 swagger 聚合成一个单一的服务。为了实现这一点,我正在学习下一个教程 https://objectpartn
我的任务是将 Swagger 安装到 Web API 项目中。 已安装:来自 nuget 的最新版本的 Swashbuckle。 (Swashbuckle.Core.Net45 和 Swashbuck
我正在编写一个 swagger 规范,并且我有三个独立的端点。我如何在文档中将它们分开?我想明确区分示例:用户、帖子和其他。所以每个人都会有一个 CRUD 描述并显示在 swagger UI 中,它看
我试图在 Swagger 中定义一个查询参数,其中包含来自预定义项目集的逗号分隔字符串,例如 ?fruits=Apples,Oranges,Bananas但我从 swagger 编辑器收到以下错误 s
我正在使用 go-swagger 来生成 API 服务器。我注意到从 swagger.yml 生成的 json 被保存在 restapi/embedded_spec.go 中. 公开该 JSON 规范
我使用的是 springfox 版本 2.9.2 和 swagger 注释 1.5.x。 ApiModel 注释支持鉴别器、子类型和父属性,这些是使多态性工作所需的,但我没有看到生成的正确的 apid
我正在尝试使用本地 swagger.json 文件在 swagger 文档中显示。 我的 swagger.json 文件位于/home/user1/swagger-ui/dist/swagger.js
我们有一些数字字段,由于遗留原因,它们具有隐式长度限制。 给定一个长度限制为 5 的数字字段,显而易见的方法是将最大值设置为 99999,但是有没有办法在 swagger 规范中指定 1.111 可以
我们的项目为单个 API 使用多个 swagger 文件,但看起来 swagger-codegen 只接受一个。在这种情况下,我们如何使用 swagger-codegen 生成代码? 最佳答案 您可以
我正在尝试使用 https://github.com/swagger-api/swagger-codegen 生成 nodejs 客户端 sdk这是我使用的命令 swagger-codegen gen
我定义了一个以 MyObject 作为参数的路径。 MyObject 具有猫和狗的属性。这些有默认值。 在 swagger-editor 中,该示例不显示默认值,但试用确实创建了一个具有正确默认值的
我最近从 Swashbuckle 过渡到 Swagger-Net .进行更改后我遇到的一个问题是,现在我无法调用需要在 Authorization header 中发送 token 的 API。下面是
正在使用 AspNetCore 为使用 IIS 托管的 Web 应用程序设置 swagger。 .json 页面加载并且似乎可以很好地接触所有 API,但是当导航到 {localhost}/swagg
我想将任何复杂的 swagger-API-document(swagger.json) 解析为 Java 对象。 可能是列表> 有哪些可用选项? 我正在尝试使用 io.swagger.parser.S
我要将我的 API 服务器集成到 Google Cloud Endpoints。 到目前为止,Google Cloud Endpoints 支持 swagger 2.0。 但是我的依赖项/库现在是 u
我是 swagger 的新手,发现有两个用于 swagger 注释的包:io.swagger.annotations 和 com.wordnik.swagger.annotations。我想知道它们之
好的,我有许多 io.swagger.models.Swagger 对象,我已将它们合并到一个新的 super Swagger 中。现在我想要 super html。我怎样才能得到这个?请注意,为了获
我们当前的部署模式要求我手动编写 swagger json 输出,该输出将由我公司使用的基于 Swagger 的 UI 使用。我希望我正在编写的 json 能够提供“默认”值来填充所有输入字段(包括
我有以下 HTTP 触发的 Azure 函数。我已经使用此链接为我的端点设置了 Swagger here .以下 API 需要一组查询字符串参数,即 "name"、"email"、"phone",因此
我正在努力让 Swagger 正确呈现我的 ServiceStack 服务。 我希望看到一个 UserId 字符串作为表单参数,一个 PrivateCustomer 对象作为主体参数,但是尽管 Use
我是一名优秀的程序员,十分优秀!