我正在使用英特尔XDK为Android设备制作移动应用程序,我一直在使用模拟器和我的本地开发服务器(127.0.0.1)来测试我的PHP代码。我一直在使用以下方式联系我的服务器$.ajax()
,$.post()
和$.get()
。然后我决定,我已经到了一个合适的位置,我应该构建应用程序APK文件,将PHP源文件推送到在线网站并通过适当的移动设备进行测试。所以我做了,我通过从PMA导出我当前的数据来创建数据库,然后将我所有请求中的所有URL更改为指向正确的位置并将我的PHP源推送到FTP。然后我测试了我的应用程序并对结果感到非常震惊。
错误#1 :
PHP致命错误:在写入上下文中不能使用函数返回值 /home/scrifalr/public_html/sm/api/v1/modules/register/register.php on 第9行
我的修复方法:
我检查了来源,显然在将此!empty(trim($_POST['username']))
更改为empty($_POST['username'])
之后似乎已修复此错误。
所以 提问 。为什么这个错误没有显示在我的本地服务器上,而是告诉我那时我不能这样做?
错误#2 :
我有一个登录/注册,发送所有工作的请求,我改变了上面的PHP,他们开始工作。但是我有一个似乎无法正常工作的注销页面,代码如下所示:
logout.html
<!DOCTYPE html>
<html>
<head>
<link type="text/css" rel="stylesheet" href="css/styles.css">
<meta http-equiv="Content-type" content="text/html; charset=utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
<script src="http://code.jquery.com/jquery-latest.min.js"></script>
<script src="intelxdk.js"></script>
<script src="cordova.js"></script>
<script src="xhr.js"></script>
<script src="js/libs/app.js"></script>
<script src="js/libs/functions.js"></script>
<script src="js/logout.js"></script>
<title>Logout</title>
</head>
<body>
</body>
</html>
正如你所看到的,它除了包含之外什么都没有。以下文件是JavaScript文件:
logout.js
window.onload = function () {
getSessionData();
$.post(
"http://sm.script47.net/api/v1/modules/logout/logout.php", {
"userID": window.userID
}, function (data) {
alert(data);
if (data == 1) {
document.location.href = "index.html";
} else {
showTimedMessage(data, "error", 4000);
}
}
);
};
正如你所看到的,它包含post请求和一个名为getSessionData()
的函数,所以在看起来像是一个试图调试的时代后,我得出的结论是getSessionData()
失败了这似乎很奇怪,因为它在模拟器中工作,并且所请求文件的所有路径都是正确的。只为那些想要看到这个功能的人:
window.token = null;
window.userID = null;
window.username = null;
window.emailAddress = null;
window.IP = null;
function getSessionData() {
$.ajax({
url: 'http://sm.script47.net/api/v1/modules/sessionData/sessionData.php',
"type": "GET",
dataType: "json",
async: false // This comment is not in the code, I know I shouldn't have this I'm using it for now and it works with it like this.
}).done(function (data) {
window.token = data.token;
window.userID = data.userID;
window.username = data.username;
window.emailAddress = data.emailAddress;
});
}
所以 问题二 就是在我彻底测试它并确保所有路径都正确并上传完全相同的代码之后,为什么有些请求是发送例如登录,注册其他人(注销)不工作?
答案 0 :(得分:0)
经过一些调试后发现AJAX调用失败,因为不允许同步AJAX调用。