使用 Google App Engine 的 Channel API 和开发服务器时出现 JavaScript 错误



我正在编写一个使用Channel API的Python GAE应用程序,除了在使用开发服务器时在Firefox错误控制台中出现非致命的浏览器错误外,一切都很好。每个Channel API应用程序基本上都是一样的,所以我将展示我在示例Channel Tac Toe应用程序中看到的内容。

它从一个语法错误开始,其中显示的源代码总是只有数字"1":

Error: syntax error
Source File: http://localhost:8080/_ah/channel/dev?command=connect&channel=channel-2053758219-1329727351-185804764220139124118185804764220139124118
Line: 1, Column: 1
Source Code:1

接下来是一个"格式不正确"的错误(仅在Channel Tac Toe中):

Error: not well-formed
Source File: http://localhost:8080/_ah/channel/dev?command=poll&channel=channel-2053758219-1329727351-185804764220139124118185804764220139124118&client=1
Line: 1, Column: 1
Source Code:{"winner": null, "userX": "185804764220139124118", "moveX": true, "winningBoard": null, "board": "         ", "userO": ""}

然后我得到了一系列无休止的"找不到元素"错误,大约每秒三个:

Error: no element found
Source File: http://localhost:8080/_ah/channel/dev?command=poll&channel=channel-2053758219-1329727351-185804764220139124118185804764220139124118&client=1
Line: 1

在这之后,Channel Tac Toe表现不佳(双方都想成为X玩家),尽管我的实际应用程序运行没有问题。

注意,因为这些都是JavaScript错误,所以没有堆栈跟踪。

(a) 是什么导致了这些问题?尽管我的应用程序在运行,但这些错误降低了我的信心。

(b) 没完没了的"找不到元素"消息是一个真正的问题,因为它们使得很难看到其他JavaScript错误。

我遇到过另一份关于同样问题的报告,但后续行动毫无帮助。

我的配置:Windows 7,Firefox 10.0.2(禁用附加组件),GAE 1.6.2

FWIW,问题似乎是由于Channel API的内部轮询机制没有从包含Content-type的服务器接收到响应而引起的。因此,Firefox似乎将响应的内容类型默认为text/xml

当Firefox尝试生成XMLHttpRequest.responseXML属性[1]时,可能会引发"未找到元素"错误,因为响应正文实际上是空白的,因此未找到根XML元素。

[1]https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest#responseXML

这看起来像是SDK中的一个bug。您可以在此处报告错误:http://code.google.com/p/googleappengine/issues/entry

最新更新