0



我正在使用 RobotLegs、LiveCycle DS 和 Java 开发一个 Flex 应用程序。我正在尝试使用 LCDS 实现更新功能,但遇到了一些奇怪的行为:

这是 RobotLegsexecute命令中的 ActionScript 代码,用于执行更新:

 var token:AsyncToken = services.requestService.commit(new Array(model.currentRequestDetail));
 responder = new AsyncResponder(resultHandler, faultHandler, token);
 if ( token ) token.addResponder(responder);



model.currentRequestDetail我要更新的是一个 RequestDetail 对象:

[Managed]
[RemoteClass(alias="be.fgov.mobilit.td.lcds.vo.RequestDetail")]
public class RequestDetail {

    public var id:Number;
    public var request:Request;
    public var task:Task;

    /**
     * Constructor
     */
    public function RequestDetail() {
    }
}

第一次执行 Actionscript 代码时,一切正常。函数很好地返回了 AsyncToken services.requestService.commit(),resultHandler 按预期执行,我的对象在 GUI 中更新。
但是,第二次执行此代码时,我的services.requestService.commit()函数返回一个空值,并且我的 resultHandler 永远不会到达。我怀疑我们甚至没有到达 java 汇编器。



这就是我声明 DataService 的方式:

var requestDetailService:DataService = new DataService("requestDetail");
requestDetailService.autoCommit = false;



resultHandler 和 faultHandler 都有正确的签名:

resultHandler(result:Object, token:Object = null)
faultHandler(result:Object, token:Object = null)



我们还使用了一个自定义的 java 汇编器,代码如下:

package be.fgov.mobilit.td.lcds.assemblers;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import be.fgov.mobilit.td.lcds.vo.RequestDetail;
import flex.data.ChangeObject;
import flex.data.assemblers.AbstractAssembler;

public class RequestAssembler extends AbstractAssembler {

public RequestAssembler() {
    // TODO Auto-generated constructor stub
}

public RequestDetail getRequest(Map<String, Object> identity) {
    return ServiceUtility.getLcdsService().getRequestDetail(identity);
}

public List<ChangeObject> syncRequest(List<ChangeObject> changes) {
    Iterator<ChangeObject> iterator = changes.iterator();
    ChangeObject co;
    while (iterator.hasNext()) {
        co = (ChangeObject) iterator.next();
        if (co.isUpdate()) {
            co = doUpdate(co);
        }
    }
    return changes;
}

private ChangeObject doUpdate(ChangeObject co) {
    RequestDetail requestDetail = (RequestDetail) co.getNewVersion();
       co.setNewVersion(ServiceUtility.getLcdsService().updateRequestDetail(requestDetail));
    return co;
}
}



这是汇编程序的配置:

<destination id="request">
    <properties>
<source>be.fgov.mobilit.td.lcds.assemblers.RequestAssembler</source>

        <scope>application</scope>

        <metadata>
            <identity property="id" />
            <identity property="task" />
        </metadata>

        <server>
            <get-method>
                <name>getRequest</name>
            </get-method>
            <sync-method>
                <name>syncRequest</name>
            </sync-method>
        </server>
    </properties>
</destination>




长话短说:
有没有人有线索/经验,为什么我第二次执行services.requestService.commit();它返回一个 null Asynctoken 的函数?




提前谢谢!




根据要求,我从我的服务类中添加了(剥离的)代码。如您所见,没有什么特别的事情发生:

package be.fgov.mobilit.services {
import mx.data.DataService;
import mx.messaging.Consumer;
import mx.messaging.events.MessageEvent;
import mx.rpc.http.HTTPService;

public class LiveCycleServices {

    public var requestService:DataService;

    public function LiveCycleServices() {           

        requestService  = new DataService("request");
        requestService.autoCommit = false;
    }


    /**
     * @param   MessageEvent    The event object that is dispatched by the Flex framework
     * @return  void
     * 
     * This message captures the server push messages that need to trigger an update
     * of the task list, since this is specific for every client and cannot be 
     * determined on the server side, coming from LiveCycle.
     */
    private function messageHandler(event:MessageEvent):void {
        taskListService.refresh();          
    }
}
}



这是添加我的结果和故障处理程序的地方:

var token:AsyncToken = services.requestService.commit(new   Array(model.currentRequestDetail));
var responder:AsyncResponder = new AsyncResponder(resultHandler, faultHandler, token);
if ( token ) token.addResponder(responder);
4

2 回答 2

1

当您没有要提交的更改时,aysnctoken 返回 null。希望这可以帮助。

于 2012-01-30T21:42:18.100 回答
0

WWW,这并不是真正的答案,但我需要比评论给我更多的空间。但是,我没有看到您的所有代码如何连接得足够好,无法给您一个好的答案。

一般来说,结果和故障签名不应该看起来像您描述的“正确”签名。AsyncToken 需要一个 IResponder,它的故障和结果mentods 有一个参数,即一个对象。通常,这将与故障或结果事件一起调用(视情况而定)。

现在我要进入的领域,对我来说,纯粹是理论上的。在我看来,DataService 类可能只创建一个 AsyncToken,因为连接保持打开状态。如果是这种情况,则错误的方法签名可能会损坏 AsyncToken 到无法返回以供方法使用的程度。我在您粘贴的代码中没有看到任何看起来像以自定义方式调用您的结果和错误方法的内容。

我强烈怀疑问题出在 Java 代码中。AFAIK,AsyncToken 被创建并设置为在调用之前调用响应程序中的函数(至少这似乎是与 HTTPService 或 amf 一起工作的方式)。我希望有一些错误被“有用地”抑制,因此您可能会从单步执行代码中受益。

我建议你退后一步,仔细研究一下 Robotlegs 所暗示的 MVCS 架构的“S”部分,并创建一个单独的服务类来管理整个事情,然后仅仅从一个命令开始这个过程,而不是试图在命令和服务之间来回传递控制。作为附带的好处,当您不需要连接到实际数据(例如进行设计工作)时,您可以将实际服务的实例换成测试服务。

于 2012-01-02T21:24:39.613 回答