我对jquery ajax&amp ;;有一些问题PHP。我不擅长PHP,但我必须用php创建一个登录页面。
问题是,当我试图从服务器获取一些信息时,我得到服务器错误的值。
这是我的PHP代码(如果有人知道更好的方法在服务器端创建登录,请纠正我):
<?php
//$link = mysql_connect('localhost', 'root', '') or die('A kapcsolódás nem sikerült: '+mysql_error());
$link = mysql_connect("127.0.0.1", "qm", "soR624gA") or die("Nem sikerült kapcsolódni az adatbázishoz!"+mysql_error());
mysql_query("SET NAMES UTF8");
mysql_select_db("qm", $link);
$uname = mysql_real_escape_string($_POST['name']);
$pass = mysql_real_escape_string($_POST['pass']);
$fetch = mysql_query("SELECT * FROM felhasznalok WHERE nev ='{$uname}' AND jelszo = Sha1('{$pass}')") or die(mysql_error());
if (mysql_num_rows($fetch) == 1) {
$a = array();
$['true'] = 'true';
echo json_encode($a);
}else{
$a = array();
$['true'] = 'true';
echo json_encode($a);
}
?>
以下是客户端登录的代码:
function handleLogin(){
var _url = preUrl + "login.php";
var name = $("#loginForm #name").val();
var pass = $("#loginForm #pass").val();
$.ajax({
type: 'POST',
url: _url,
data: {name: name, pass: pass},
dataType: 'jsonp',
beforeSend: function(){
if((!name) || (!pass)){
notify('error','Kérlek tölts ki minden adatot!');
return false;
}else{
$("#loginForm #loginBtn").prop("disabled", true);
}
},
success: function(data){
if(data[0].true == 'true'){
window.localStorage["username"] = name;
window.localStorage["password"] = pass;
$.mobile.changePage("#wall",{transition:"slide", reverse:false});
}else{
$('#loginForm #name').val("");
$('#loginForm #pass').val("");
notify('error','Hibás adatok!');
}
},
error: function(err){
//átírni ha a cordovajs be lesz szúrva!!!
alert('Hiba: '+err.message);
}
});
$("#loginForm #loginBtn").prop("disabled", false);
return false;
}
我在不同的服务器上试过但没有改变。我只收到错误。
答案 0 :(得分:2)
学习基本的php:$['true'] = 'true';
是一个彻底的语法错误。这是导致服务器500错误的最可能原因。
答案 1 :(得分:2)
你写了一个错字:
$['true'] = 'true';
应该是
$a['true'] = true;
(请注意$ a )
另请注意,无论您的登录是否成功,它都将使用 true 填充“真实值”。看看你的Javascript,这不是你想要的。考虑在else语句中将其设置为 false 。
答案 2 :(得分:1)
添加类似的字符串以查看php脚本中的错误:
error_reporting(E_ALL);
ini_set('error_log', 'path_to_log_file');
ini_set('log_errors_max_len', 0);
ini_set('log_errors', true);