Swagger2.9.2进入API界面报NumberFormatException异常

原文出处http://www.yund.tech/zdetail.html?type=1&id=dc9ac5bfa5b4d6348cb7e15e4edc3600    

作者:jstarseven 


  

问题发现

Swagger2.9.2版本,在访问swagger首页的时候,控制台报错。

 1 WARN 19699 --- [nio-1111-exec-4] i.s.m.p.AbstractSerializableParameter    : Illegal DefaultValue null for parameter type integer
 2 
 3 java.lang.NumberFormatException: For input string: ""
 4     at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65) ~[na:1.8.0_171]
 5     at java.lang.Long.parseLong(Long.java:601) ~[na:1.8.0_171]
 6     at java.lang.Long.valueOf(Long.java:803) ~[na:1.8.0_171]
 7     at io.swagger.models.parameters.AbstractSerializableParameter.getExample(AbstractSerializableParameter.java:412) ~[swagger-models-1.5.20.jar:1.5.20]
 8     at sun.reflect.GeneratedMethodAccessor109.invoke(Unknown Source) ~[na:na]
 9     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_171]
10     at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_171]
11     at com.fasterxml.jackson.databind.ser.BeanPropertyWriter.serializeAsField(BeanPropertyWriter.java:687) [jackson-databind-2.9.6.jar:2.9.6]

问题原因

查看swagger2.9.2源代码swagger-models-1.5.20.jar中io.swagger.models.parameters.AbstractSerializableParameter,发现是由于实体类使用@ApiModelProperty时,example属性没有赋值导致的,在AbstractSerializableParameter的getExample方法中会将数值属性的example的转换数值类返回,example的默认值是"",因此当example没有赋值时,会出现上面的异常。

swagger-models-1.5.20中源代码:

 

 解决问题的四种办法:

一、勤劳致富法:将每一个数值类型上@ApiModelProperty的example都赋值数字字符串,这也太累了吧!

  

二、掩耳盗铃法:修改springboot输出日志,将io.swagger.models.parameters.AbstractSerializableParameter文件的日志级别设置成error,这也太自欺欺人了吧!

  

三、刨根问底法:不就是1.5.20的代码出的问题吗,我自己改了,重新打个包,不就行了嘛!老铁666,大佬就你了!

 

四、懒人模式法:发现swagger-models-1.5.22中解决了此问题,那我直接导入覆盖,岂不美哉,哈哈哈!一秒刷爆,继续开发,nice !

 swagger-models-1.5.22中源代码:

  替换:

 

   


 -END-

posted @ 2019-11-04 09:08  jstarseven  阅读(3909)  评论(1编辑  收藏  举报