第一种情况:
@ApiModelProperty(value = "排序", example = "1")
private int sort_order;
如上代码,如果实体类中,int类型或者long类型字段,没有写example = "1"这个默认值的话,swagger会默认为""空字符串,所以字符串转数字,就有了NumberFormatException这个异常!
解决办法: 加上 example = "1" 即可!
第二种情况:
@ApiImplicitParams({
@ApiImplicitParam(name = "page", value = "页码", required = true, dataType = "int", defaultValue = "1"),
@ApiImplicitParam(name = "rows", value = "每页的行数", required = true, dataType = "int", defaultValue = "10"),
@ApiImplicitParam(name = "code", value = "搜索条件--类型代码", dataType = "String"),
@ApiImplicitParam(name = "name", value = "搜索条件--类型名称", dataType = "String"),
@ApiImplicitParam(name = "sidx", value = "排序字段", dataType = "String"),
@ApiImplicitParam(name = "sord", value = "正序--asc,倒序--desc", dataType = "String")
})
如上代码,这是接口上面的@ApiImplicitParams注解,其中前端给传的page和rows,并非是实体类的字段,这样就没办法通过第一种方法去解决了.本人遇到的就是第二种情况,没办法只能看报错,打断点调试,最终定位到是这两个字段的原因后,结合源码获得了答案!
解决办法:
其一,改源码jar包,再通过maven依赖进来,这个比较麻烦,后来找到了一个心的方法
其二,io.springfox:springfox-swagger2:2.9.2中依赖了swagger-models的1.5.20版本,我们可以排除springfox-swagger2中的swagger-models依赖,导入io.swagger:swagger-models的1.5.21版本即可。因为1.5.21版本添加了对""空字符传的判断!
如下图: