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-


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM