- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在使用 swagger-spring-mvc 0.9.5 并且在我的响应数据中有这样的字段:
@ApiModelProperty("Some description")
private List<Account> accounts;
问题的简短版本:我怎样才能从这个带注释的 Java 得到例如通过 swagger-codegen 实现 Objective C?
由此生成的 swagger JSON 是:
accounts: {
description: "Some description",
items: {
type: "Account"
},
required: false,
type: "List"
}
我的同事将其输入 swagger-codegen 以生成 Objective C 类,但它生成的代码无法编译。
@property (nonatomic, strong) NSArray<Optional, NSArray> *accounts;
因为NSArray
(在 < >
内)不是协议(protocol)。
swagger 模板文件(mustache)为每个模型创建一个协议(protocol)。当在数组上指定该协议(protocol)时,JSONModel 会选择它以从列表/数组中的数据生成正确的模型。所以在这种情况下,预期的输出是
@property (nonatomic, strong) NSArray<Optional, MAAccount> *accounts;
这将创建一个 NSArray
的 MAAccount
的(Account
是对象类型,MA
是 swagger 已有的前缀)。
如果我们手动编辑 swagger JSON 以更改 List
至 array
(如在各种类似情况下所建议的那样),输出是正确的,但我们希望避免此手动步骤。
所以我试图让 swagger-spring-mvc 使用 "array"
:
@ApiModelProperty(value = "Some description", dataType = "array")
private List<Account> accounts;
但后来发现dataType
在 swagger-spring-mvc 0.9.5 中被忽略,从外观上看,在 springfox 2.0 中它被忽略,除非它是完全限定的 Java 类名。
有没有办法实现这一点,要么让 swagger-spring-mvc/springfox 使用 "array"
还是通过其他方式?
最佳答案
在大多数情况下,swagger 注释只是帮助 springfox 引擎推断有关类型的附加信息,如 description/hidden/readonly 等,这些信息无法从类型系统中获得。它还可以用作表示不容易推断的类型的拐杖。数据类型可以被覆盖,但正如评论中指出的那样只是为了类型安全。
Specifically, I read that dataType will be ignored unless it's a fully-qualified class name.
就像@CupawnTae 建议的那样,version 2.x of springfox支持使用代码生成友好和语言不可知的通用类型表示来呈现通用类型的选项。
在创建/配置您的摘要时,您需要使用 forCodeGeneration
指定呈现的 swagger 服务描述需要代码生成友好。选项
@Bean
public Docket docket() {
return new Docket(DocumentationType.SWAGGER_2)
...
.forCodeGeneration(true)
...;
}
这将导致 springfox 呈现泛型类型,如 List<String>
ListOfString
什么时候forCodeGeneration
设置为真List«String»
什么时候forCodeGeneration
设置为假关于java - 如何在 swagger-spring-mvc for swagger-codegen 中用 List<Something> 等泛型类型表示字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30102898/
此处给出了基本的 Watir WebDriver 命令: http://watirwebdriver.com/web-elements/ 在大多数情况下,作者使用 :something => 'som
这里给出了基本的 Watir WebDriver 命令: http://watirwebdriver.com/web-elements/ 在大多数情况下,作者使用:something => 'some
我可以发誓我看到一个对象是以这种方式创建的。 somethingelse 有什么作用? 最佳答案 从字面上看,可能类 JSomething 有一个名为 somethingelse 的字段,类型为 JS
我正在阅读一些代码,我看到了一个如下所示的比较: a = b = c 看到在 Javascript 中搜索相等或比较如何产生补救结果,有人愿意解释发生了什么吗? 编辑:这些都是我们在这里讨论的所有对象
这个问题在这里已经有了答案: Is there a "null coalescing" operator in JavaScript? (19 个回答) 关闭 4 年前。 快速提问。我可以用更短的方
我正在尝试为我的网上商店做一个过滤器。我有以下查询 $column = mysqli_query($link, "SELECT brand FROM shields WHERE brand=".$br
我正在尝试将 json 文件映射到 mysql 数据库,请参阅 undefined index Name对于代码 我认为的问题是第三个条目中的任何一个元素都没有值,但有一个名为 aws:autosca
这个问题已经有答案了: Question mark and colon in JavaScript (8 个回答) 已关闭 5 年前。 我从 https://github.com/andrewgodw
我们知道编程语言中的后增量和前增量。据我所知,后增量意味着为下一条语句增加值。所以,something++ 等同于 something = something + 1,不是吗? 但是当 somethi
我有两个结构非常相似的表。 Universidades nombre | contenido | becas | fotos etc etc etc Internados nombre | todo
所以我有3张 table , Companies (company_id, company_name) Stock_Exchanges(stock_exchange_id, stock_exchang
我刚刚开始浏览 backbone fundamentals并且不太明白这里发生了什么: this.$input = this.$('#new-todo'); 有人可以给我概述/分割这实际上是做什么的吗
/*/ comment here do some thing. /*/ do some thing. //*/ 为什么人们会这样写代码?这是一个好的做法吗? 最佳答案 它通常只在暂时测试某些东西时使用
我正在查看一些微 Controller C 头文件,并且有这样的代码: #define OSCCONL OSCCONL extern volatile uint8_t OSCCONL __attrib
在 :contains jquery 调用中实现 OR 语句的最佳方法是什么? 谢谢 最佳答案 唯一的办法就是放两个 together : $('a:contains(b), a:contains(c
我有几个表需要连接。这些表是: 玩家 名字 姓氏 性别 location_id (其他不相关的列) 和 score_entries 得分 日期时间 玩家编号 (其他不相关的列) 我需要根据 playe
这个问题已经有答案了: Difference between single quotes and double quotes in Javascript [duplicate] (6 个回答) 已关闭
这是一段代码: if resp.email is None or resp.email == "": 我认为以下内容更清楚: if not resp.email: 第一个选项比第二个选项有什么优势吗?
我遇到了 this answer张贴者建议 的简写 if(typeof MyNamespace === 'undefined'){ var MyNamespace = {}; } 是 var
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
我是一名优秀的程序员,十分优秀!