gpt4 book ai didi

mysql - qooxdoo 远程请求未完成

转载 作者:行者123 更新时间:2023-11-29 14:17:11 25 4
gpt4 key购买 nike

我有简单的应用程序,我需要从 MySQL 获取数据。我读到我可以使用 *.php 文件中服务器上的脚本来完成此操作,我所需要做的就是从我的 qooxdoo 应用程序运行此文件并获取打印数据。这是一段代码:

doWysyl.addListener("execute", function(e)      //doWysyl is button
{
var req = new qx.io.remote.Request("http://localhost/db_connector.php", "GET", "application/json");
req.addListener("completed", function(e)
{
alert("Something");

});
req.send();

}, this);

db_connector.php 文件:

<?php
$db = mysql_connect('localhost', 'root', '');
if (!$link) {
die('Can't connect: ' . mysql_error());
}
$result = mysql_query("SELECT Id FROM gitterbox WHERE Ukryj=0")
$dane = array();
while ($row = mysql_fetch_assoc($result)) {
$dane [] = $row["Id"];
}
mysql_close($link);
echo json_encode($dane);
?>

我的问题是alert("Something");永远不会显示,就像完成的事件永远不会被触发一样。我也尝试过不同的事件,但没有任何帮助。我确定 db_connect.php 已打开,因为我已经检查过。

<小时/>

好的,我编辑了代码以使用 Xhr 请求,现在看起来像:

doWysyl.addListener("execute", function(e) {
var req = new qx.io.request.Xhr("http://localhost/db_connector.php", "GET");
req.addListener("success", function(e) {
alert("success");
}, this);
req.addListener("fail", function(e) {
var reqa = e.getTarget()
var response = req.getResponse()
alert("fail "+response+". Code: "+reqa.getStatus())
}, this);
req.send();
}, this);

但问题是我总是会触发失败事件,并且在警报中我收到消息:

fail null. Code 0
<小时/>

我在警报之前添加了断点,这就是堆栈跟踪(使用 Chrome 和 Windows 7 x64):

(anonymous function) (class/custom/MainWindow.js:27)
qx.Class.define.members.dispatchEvent (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/event/dispatch/Direct.js:134)
wrappedFunction (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/Interface.js:451)
qx.Class.define.members.dispatchEvent (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/event/Manager.js:873)
qx.Class.define.statics.fireEvent (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/event/Registration.js:310)
qx.Mixin.define.members.fireEvent (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/core/MEvents.js:169)
qx.Class.define.members._onError (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/io/request/AbstractRequest.js:773)
(anonymous function) (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/lang/Function.js:293)
qx.Bootstrap.define.members._emit (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/bom/request/Xhr.js:440)
qx.Bootstrap.define.members.__readyStateChangeDone (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/bom/request/Xhr.js:897)
qx.Bootstrap.define.members.__readyStateChange (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/bom/request/Xhr.js:869)
qx.Bootstrap.define.members.__onNativeReadyStateChange (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/bom/request/Xhr.js:808)
(anonymous function) (/D:/qooxdoo-2.0.2-sdk/framework/source/class/qx/Bootstrap.js:551)

我发现有趣的是this ,在网络选项卡中。我希望这有帮助。

最佳答案

首先我建议使用 qx.io.request.Xhr :

您可以在此页面获得有关使用它的详细介绍:

http://manual.qooxdoo.org/1.5/pages/communication/request_io.html

如果你使用Xhr,我建议听“success”和“fail”或“statusError”。这会提示您的请求有什么问题。

关于mysql - qooxdoo 远程请求未完成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12448302/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com