1. 问题描述:
项目中配置 swagger2 2.9.2
, 启动项目, 当访问 swagger-ui.html
页面时, 服务器抛异常:
io.swagger.models.parameters.AbstractSerializableParameter [421] -| Illegal DefaultValue null for parameter type integer java.lang.NumberFormatException: For input string: "" at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65) at java.lang.Long.parseLong(Long.java:601) at java.lang.Long.valueOf(Long.java:803) at io.swagger.models.parameters.AbstractSerializableParameter.getExample(AbstractSerializableParameter.java:412) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498)
2.报错原因
这是由于实体类使用@ApiModelProperty时,example属性没有赋值导致的,在AbstractSerializableParameter的getExample方法中会将数值属性的example的转换数值类返回,example的默认值是"",因此当example没有赋值时,会出现上面的异常。getExample方法如下
1 @JsonProperty("x-example") 2 public Object getExample() { 3 if (example == null) { 4 return null; 5 } 6 try { 7 if (BaseIntegerProperty.TYPE.equals(type)) { 8 return Long.valueOf(example); 9 } else if (DecimalProperty.TYPE.equals(type)) { 10 return Double.valueOf(example); 11 } else if (BooleanProperty.TYPE.equals(type)) { 12 if ("true".equalsIgnoreCase(example) || "false".equalsIgnoreCase(defaultValue)) { 13 return Boolean.valueOf(example); 14 } 15 } 16 } catch (NumberFormatException e) { 17 LOGGER.warn(String.format("Illegal DefaultValue %s for parameter type %s", defaultValue, type), e); 18 } 19 return example; 20 }
3. 解决办法:
<swagger-models.version>1.5.22</swagger-models.version> <swagger2.version>2.9.2</swagger2.version>
<dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>${swagger2.version}</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>${swagger2.version}</version>
<!--排除swagger2的annotations和models依赖,然后再引入1.5.21版本的annotations和models依赖--> <exclusions> <exclusion> <groupId>io.swagger</groupId> <artifactId>swagger-models</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>io.swagger</groupId> <artifactId>swagger-models</artifactId> <version>${swagger-models.version}</version> </dependency>