问题:
还是升级到3.1的问题,直接上图,现象如下:
我们的系统里,有一些查询条件是从枚举转化过来的,但是为了统一,界面渲染的时候追加了一个“请选择”,value为-999,这种场景很多很多,
可以看到-999不在枚举的定义里,只要我以当前选择状态提交请求,后端全局的modal valid就会报错,说-999不是有效的值。
这个情况在我之前2.1里面不存在的,升级到3.1就这样了。
调查:
我同事也在看,居然在github里有人提过这样的issue:https://github.com/dotnet/aspnetcore/issues/14824
官方说了,在3.1里面,不管这个参数了。
完了我们去看看3.1版本下,这个枚举绑定器的源码吧:https://github.com/dotnet/aspnetcore/blob/v3.1.2/src/Mvc/Mvc.Core/src/ModelBinding/Binders/EnumTypeModelBinder.cs
仔细看他里面说的很清楚,不在枚举的定义范围内,绑定的值,全都无效的,方法会返回fasle,然后checkmodel就会爆error。此逻辑的初衷的确是好的,因为绑定更严谨了,新项目可以尝试遵守下。
解决:
1. 要么我改前端,但是想想还是算了,好多地方都用。
2. 自己重写一个,因为IsDefinedInEnum方法被它定义成私有的了,本想着可以扩展,想想还是重新写了,代码如下:
模型绑定三板斧-xxxModelBinder:
模型绑定三板斧-xxxModelBinderProvider:
模型绑定三板斧-替换:
至此,就适配了这个问题