我正在使用grails version 2.3.9
开发应用程序。在那里,我正在使用复选框呈现列表。用户可以选择任何行并提交页面。在服务器端,我使用命令对象来绑定数据。
我的命令对象 -
@Validateable
class MyCO {
List<MyDoamin> myDomains = ListUtils.lazyList([], FactoryUtils.instantiateFactory(MyDoamin))
...
static constraints = {
myDomains nullable: false, validator: { val, obj ->
if (val.size() < 1) {
return "error.code"
}
}
...
}
}
查看 -
<g:each in="${myDomains}" var="myDomain" status="idx">
<tr>
<td>
<input type="checkbox" name="myDomains[${idx}].id" value="${myDomain.id}" checked>
</td>
...
</tr>
</g:each>
动作 -
def myAction(MyCO myCO) {
if (myCO.validate()) {
...
} else {
log.error "-----INVALID-----"
...
}
}
此代码工作正常。但是,如果用户选择其索引(idx)值大于255的行,则数据绑定不起作用。
请求参数 -
[myDomains [256] .id:66,myDomains [256]:[id:66],action:myAction, 控制器:myController的]
我也试过
List<MyDoamin> myDomains
和
List<MyDoamin> myDomains = [].withDefault { new Client() }
在命令对象中,但结果相同,没有数据绑定。
我在这里做错了吗?我该如何解决这个问题?
答案 0 :(得分:5)
默认情况下,集合自动增长限制设置为255:
您可以通过将grails.databinding.autoGrowCollectionLimit
中的Config.groovy
设置为其他内容来更改此设置。
这种限制的原因是攻击者可以通过在数据绑定期间创建数千个对象来制造拒绝服务攻击,这种攻击耗尽了所有内存,这不是您想要的。