IBM Worklight 6.0 - 经常出现“从客户端收到错误令牌”错误

时间:2013-07-19 15:10:52

标签: ibm-mobilefirst worklight-server

我有一个带有HTTP适配器的Worklight应用程序,它连接到另一个应用程序,以便检索要在移动设备上显示的数据(目前使用Android 4.0.4进行测试)。

当应用程序启动时,我从HTTP适配器调用三个过程并显示所有三个过程的结果。

当我在浏览器中运行我的应用程序并将其预览为Common时,一切正常。
当我在实际手机上运行应用程序时出现问题。大多数情况下,我的过程调用中的1或2次失败并且数据不显示,但似乎其中一个(第一个)似乎总是起作用。在极少数情况下,所有3个过程调用都将检索数据,但我无法一致地重现这种情况。

当程序失败时,我在Worklight Development Server控制台中收到错误:

[ERROR ] FWLSE4007E: Received bad token from client. Server token:'null', client token:'b3fuqgdid2701hu855n89pldpk'. [project trunk]

有时候,我会收到此错误,但不太常见:

[ERROR ] FWLSE0203E: Received bad instance Id from client. Server instance Id:'3f9eveddc7br5mq3ll0nq89miu', client instance Id:'ut5m5f01i3bkq5l78m54uq137o'. [project trunk]

应用程序总是尝试WL.Client.invokeProcedure所有过程,并且当调用成功时,我的onSuccess函数运行,但是当其他过程无法加载它们的数据时,onFailure函数永远不会发生。

我的适配器看起来像这样:

<displayName>Adapter</displayName>
<description>Adapter</description>
<connectivity>
    <connectionPolicy xsi:type="http:HTTPConnectionPolicyType">
        <protocol>http</protocol>
        <domain>10.50.22.161</domain>
        <port>9000</port>   
    </connectionPolicy>
    <loadConstraints maxConcurrentConnectionsPerNode="5"/>
</connectivity>

<procedure name="getProcesses" securityTest="securityTest" />
<procedure name="getTasks" securityTest="securityTest" />
<procedure name="metricsList" securityTest="securityTest" />
<procedure name="getMetric" securityTest="securityTest" />
<procedure name="getAllHashTags" securityTest="securityTest" />
<procedure name="getMessages" securityTest="securityTest" />
<procedure name="getMentions" securityTest="securityTest" />
<procedure name="getConversations" securityTest="securityTest" />
<procedure name="getServerTime" securityTest="securityTest" />

当我从过程中删除securityTests时,错误似乎发生的频率较低,但仍然会发生。

这是什么问题?或者我如何调试Worklight Server以确定原因?

我正在使用版本为6.0.0.20130701-1413的Eclipse Worklight插件。

2 个答案:

答案 0 :(得分:2)

这听起来与不久前发现的种族状况缺陷非常相似。

几种可行的解决方法:

  1. 确保{<1}} 之前调用适配器程序
  2. 在应用程序启动后允许一些延迟,然后才调用适配器程序
  3. 您也可以尝试将其添加到JavaScript中:

    WL.Client.connect
  4. 与上述3相同,但wl_noDeviceProvisioningChallengeHandler.handleFailure = function() { WL.Client.connect(); };

  5. 问题:在initOptions.js中,您是否将WL.Client.reloadApp()设置为“true”或“false”?

答案 1 :(得分:1)

在调用程序之前,必须调用WL.Client.connect()并等待它的成功回调。