原文出处: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-