我正在使用GWT 2.4编辑器并请求工厂框架。我有一个模型Trip,它有一个地址'origin'和一个Address'destination'。通过UI创建Trip时,会自动创建这两个地址并将其分配给Trip。用户填写详细信息并保存。出于某种原因,我在尝试持久保存到服务器时收到“autobean freeze error”。此代码在GWT 2.3中有效,我无法切换回来。我希望它不是GWT 2.4中的错误。以下是我正在做的一些示例代码:
RequestContext request = requestFactory.request();
TripProxy trip = request.create(TripProxy.class);
trip.setOrigin(request.create(AddressProxy.class));
trip.setDestination(request.create(AddressProxy.class));
driver.edit(trip, request);
this.trip = trip;
// … on save button clicked (different method)
RequestContext request = driver.flush();
request.save(trip).with(driver.getPaths()).fire(someReceiverImpl);
结果:
java.lang.IllegalStateException: The AutoBean has been frozen
at com.google.web.bindery.autobean.shared.impl.AbstractAutoBean.checkFrozen(AbstractAutoBean.java:195)
at com.google.web.bindery.autobean.shared.impl.AbstractAutoBean.setProperty(AbstractAutoBean.java:270)
at sun.reflect.GeneratedMethodAccessor53.invoke(Unknown Source)
对fire
的调用成功完成,但是在requestfactory内的某处,会抛出上述错误。奇怪的是,实体保存在服务器上,但不强制执行验证。当我简化模型并删除地址关联时,验证和保存工作。我的主要问题是autobean冻结错误;验证的东西是次要的。
编辑:在进一步调查中,我发现实体正在向服务器发送并且按预期持续存在。它返回时抛出上述异常。 AddressProxy是一个ValueProxy,它看起来像RF不喜欢Trip带回这些关联。返回null'修复'问题,但这显然不会长期工作。
答案 0 :(得分:14)
我知道这比你要求的要多得多,但这三个提示帮助了我(来自here):
尝试编辑已锁定的实体。
如果实体被冻结(锁定以进行更改),则不能:
更改其属性
在requestContext方法调用中使用它。
如果您尝试这样做,您将收到异常: java.lang.IllegalStateException:AutoBean已被冻结。
当实体可能被冻结?
作为回复返回的每个实体都被冻结
将冻结在requestContext调用中使用的每个实体。
在第一种情况下,解决方案很简单 - 您只需要解锁给定的实体。为此,您必须使用RequestContext类的实例并调用edit()方法。
StudentRequest req1 = requestFactory.studentRequest();
StudentProxy s2 = req1.edit(s1);
在第二种情况下,您不应再使用给定实体,因为已经分配了requestContext,所以无法编辑它。如果要更改它,则必须再次从服务器检索此实体的实例,并按照a)的说明进行操作。
尝试在已经分配了requestContext的实体上调用requestContext.edit()。
如果您已从服务器检索实体或创建了新实体,并且您尝试使用另一个RequestContext来编辑它,例如这样:
StudentRequest req = requestFactory.studentRequest();
s1 = req.create(StudentProxy.class);
// s1 is connected with "req" and one context is just enough for it
StudentRequest reqZZZ = requestFactory.studentRequest();
reqZZZ.edit(s1); // you cannot do it - here exception will be thrown
你肯定会收到一个例外:
java.lang.IllegalArgumentException:尝试编辑以前由另一个RequestContext编辑的EntityProxy
在有bean的情况下,您可能会遇到此问题,但您无法跟踪在某些先前方法调用中创建或编辑Bean的请求上下文。在这种情况下,您必须将先前的requestContext保存在某处,或将其与实体一起发送到感兴趣的点。最好的解决方案可能是创建一个保存当前使用请求的特殊层。
尝试重用已被触发的请求上下文。
您可以使用请求上下文来创建和编辑许多不同的实体(也是不同类型的实体)。您还可以累积应该触发的方法。但你不能做的是尝试两次使用它来发出请求。如果您已创建请求并在其上调用fire()方法,则无法再次执行此操作。如果您这样做,您将得到: java.lang.IllegalStateException:请求已在进行中。
解决方案是简单地创建一个新的requestContext。
答案 1 :(得分:0)
这是因为服务器上没有使用相同的EntityManager。