- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
实际问题:是否可以选择 PHP 版本 (5.6、7.1、7.2、...) 生成代码?
我从 https://api.otto.market/docs 得到了一个 swagger.json
应该是 openapi.json
左右,因为该文件包含 "openapi": "3.0.3",
。无论如何......
到目前为止我发现它们(swagger 和 openapi-generator) 似乎有用于代码生成的模板。
这些模板是用所用版本的语言编写的。
这个( openapitools/openapi-generator-cli )
docker run --rm -v ${PWD}:/local openapitools/openapi-generator-cli generate \
-i /local/path/to/swagger.json \
-g php \
-o /local/path/to/generated/code/
用
创建一个composer.json
...
"require": {
"php": "^7.3 || ^8.0",
...
},
...
我现在可以使用模板并更改要求。
但我认为这不是代码生成器的目标。
有关添加到底部的模板的信息。
我猜应该有为其他 PHP 版本编写的模板。
但是我该如何选择呢?
有吗?
Swagger:据我所知,swagger 排在第一位,而 openapi-generator 是一个分支。
所以我试着 Swagger :
docker run --rm -v ${PWD}:/local swaggerapi/swagger-codegen-cli generate \
-i /local/path/to/swagger.json \
-l php \
-o /local/path/to/generated/code/
Swagger 为 PHP 5.5 创建了代码(从生成的 composer.json
开始)。
但它会带来警告并且生成的代码看起来“已损坏”。
我其实并不奇怪,因为该文件是为 openapi": "3.0.3
制作的。
但我看到的是:swagger 有适用于 PHP 5.5 的模板。
我个人目前的结论:
我可以真正快速地生成代码。对于一个我并不(必须)知道的 API。
但是,如果我无法更改语言版本,这对我有何帮助?
我在 2 个项目中需要一个 API 客户端。
一个在 PHP 7.1 中,另一个在 7.3 中。我该如何解决这个问题?
有人必须处理这个吗?或者有什么想法?
信息
模板:如何使用模板:
调用 docker run --rm -v ${PWD}:/local openapitools/openapi-generator-cli author template -g php -o/local/templates/
将所有模板保存到路径 templates/
.
然后你可以 f.e.将 composer.mustache
复制到 f.e. deploy/templates/
并更改它。
在生成代码时,您使用 -t/local/deploy/templates
来使用您的 更改的模板。示例:
docker run --rm -v ${PWD}:/local openapitools/openapi-generator-cli generate \
-i /local/path/to/swagger.json \
-g php \
-o /local/path/to/generated/code/ \
-t /local/deploy/templates
最佳答案
Old versions of OpenAPI Generator (例如 3.0.0、4.0.0)支持旧的 PHP 版本。
要在 OpenAPI 生成器 CLI 版本之间轻松切换,您可能需要使用 NPM CLI wrapper for OpenAPI Generator .
关于php - swagger-codegen 或 openapi-generator PHP 版本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70118794/
我们即将为我的客户端实现一个服务 API,它由许多服务组成,比如说 ServiceA、ServiceB 和 ServiceC。每个服务都可以随着时间的推移(独立地)引入新版本,而旧版本仍然存在。所以我
我正在使用 OpenAPI 3 并有两个查询参数,其中至少一个是必需的,但哪个无关紧要。 即,作为sudocode: if parameter_1 OR parameter_2: do stu
为了生成客户端库,我会在构建时获取 Quarkus 生成的 openapi yml 文件。 目前我发现获取它的唯一方法是运行服务器并从/q/openapi 端点获取它,但在这个过程中必须运行服务器只是
假设我有一个描述 API Foo 的 OpenAPI 3 文档,如下所示: openapi: 3.0.0 info: version: '1' title: Foo paths: /foo:
我正在使用 FastAPI,它允许 pattern=re.compile("(?P[42a-z]+)...") . https://editor.swagger.io/显示此模式的错误。 我的猜测是
我有一个 Spring boot Gradle 项目,我想获取它的 OpenAPI 规范 YAML 文件。 据我了解官方swagger-core不支持 Spring boot 项目,所以我找到了 sp
我正在尝试记录包含各种身份验证是可选的端点的现有 API。也就是说,如果用户获得授权,则返回的数据比未授权时返回的数据多。 无法在 OAspec v3 中明确找到。是否有编码技巧来定义这种情况? 我目
Here它说我可以引用另一个文件中单个路径的定义,但该示例似乎引用了整个文件,而不是 paths 下的单个路径定义。目的。如何在另一个文件的 paths 中分配单个路径目的? 例如,我有 Anothe
我在 SwaggerHub 注册并使用 OpenAPI 3.0 创建了一个新 API。在我的 API 中,/tasks path 有 2 个非必需参数,但我无法将它们设置为不需要 - 编辑器显示“不允
在 OpenAPI 3.0 Specification ,根OpenAPI Object有 servers属性是 Server Objects 的数组.和 Path Item Object还允许可选的
我想要做的是指定有时对 API 调用的响应可能是 PDF 文档,有时是 JSON。我想以 OpenAPI 3.0 格式执行此操作。对于 PDF,响应将如下所示: responses:
我正在编写一个返回 MP3 文件的 API YAML。我不熟悉多媒体响应。在通过 Google 时,我发现我可以使用 audio/mp3 内容类型。但我找不到任何例子来说明如何去做。我应该如何处理这种
我正在寻找一个 JS 库(最好能在浏览器中使用)来: 根据 OpenAPI 3.0 架构(YAML 或 JSON)检查特定的 JSON 负载(通常是来自 API 的响应) 使用从 OpenAPI 3.
我正在构建一个简单的 OpenAPI 3 YAML 规范,如下所示: paths: /query: get: parameters: - $ref: '#/co
与 draft-07 相比,它定义了: { "type": ["object", "boolean"], "properties": { ... "$r
我正在尝试使用 OpenAPI 3、YAML 来构建 API 定义。 我一直在使用文档 https://swagger.io/docs/specification/adding-examples/关于
我有一个 Open API 3 规范的 yaml 文件,它有一些 x- 前缀的属性。我正在尝试使用 openapi-generator-cli 生成一个 Angular Typescript SDK。
我目前正在按照 Oracle 本身的指南和教程构建基于 Helidon Microprofile 的微服务,但在使用注释时遇到了与“自动 OpenAPI 规范生成器”相关的问题。 我的 POM 包含
我必须从头开始创建一个rest api。通过手动完成大部分工作,我已经对 Jersey 有了一些经验。 我想现在就做,因为这个项目是新的。因此,我目前正在尝试每次尝试 openapi 3.0 在线编辑
我想将以下 JSON 表示为 schema在 OpenAPI 3.0 API 定义中: { get-question: { question-id:string } } 到目前为止,我已经写了
我是一名优秀的程序员,十分优秀!