报错详情:
java.lang.NumberFormatException: For input string: ""
at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65) ~[na:1.8.0_191]
at java.lang.Long.parseLong(Long.java:601) ~[na:1.8.0_191]
at java.lang.Long.valueOf(Long.java:803) ~[na:1.8.0_191]
at io.swagger.models.parameters.AbstractSerializableParameter.getExample(AbstractSerializableParameter.java:412)
...
报错原因:
该异常出现于springfox-swagger2
的2.9.2
版本,在对@ApiModelProperty
注解进行处理时,对于example
属性存在要求。如使用@ApiModelProperty
的字段为Integer
,则需要标注为@ApiModelProperty(example = "100")
,若无example
标注,则会默认为空字符串 ""
,所以引发字符串转数字的异常。
此异常属于swagger-models
的Bug,在1.5.21
版本进行了修复。由于springfox-swagger2
的2.9.2
版本依赖的是swagger-models
的1.5.20
版本,所以出现该异常。
解决方法:
1.将springfox-swagger2
中的swagger-models
进行移除,并自行添加该依赖。
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.9.2</version>
<exclusions>
<exclusion>
<artifactId>swagger-models</artifactId>
<groupId>io.swagger</groupId>
</exclusion>
</exclusions>
</dependency>
<!--1.5.21版本及以上均可 但建议只提升至1.5.21-->
<!--若要提高至高版本,需同时对swagger-annotations进行移除和手动添加,以防止不兼容-->
<dependency>
<groupId>io.swagger</groupId>
<artifactId>swagger-models</artifactId>
<version>1.5.21</version>
<scope>compile</scope>
</dependency>
2.将pom文件中的springfox-swagger2
版本进行修改,2.9.2
版本出错,降为2.8.0
即可。
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.8.0</version>
</dependency>