从php返回值到javascript


Return value from php to javascript

我写了一个注册/登录表单,通过POST将用户信息发送到正在查找数据库的PHP。我希望PHP向js返回一个正确或错误的值,但我现在不知道该怎么做。这里是我的js:

    ui.onClick_regsubmit=function()
{
var fname=document.getElementById('fname').value;
var lname=document.getElementById('lname').value;
var password=document.getElementById('password').value;
var mail=document.getElementById('mail').value;
var affiliation=document.getElementById('affiliation').value;
var data = new FormData();
var xhr = (window.XMLHttpRequest) ? new XMLHttpRequest() : new activeXObject("Microsoft.XMLHTTP");
data.append("fname",fname);
data.append("lname",lname);
data.append("password",password);
data.append("mail",mail);
data.append("affiliation",affiliation);
xhr.open( 'post', 'PHP/registration.php', false );
xhr.send(data);
window.alert(affiliation);
}

和php:

<?php
     mysql_connect('localhost','root','') or die('Cannot connect mysql server');
       mysql_select_db('ChemAlive_login')  or die('cannot connect database');
   $lname=$_POST['lname'];
   $fname=$_POST['fname'];
  $password=$_POST['password'];
  $mail=$_POST['mail'];
  $affiliation=$_POST['affiliation'];
  $q=mysql_query("select * from login where mail='".$mail."' ") or die(mysql_error());
  $n=mysql_fetch_row($q);
  if($n>0)
{
  $q=mysql_query("select password  from login where mail='".$mail."' ");
  $pp=mysql_fetch_row($q);
  if($pp[0]=$password) echo "ok";
  else echo "wrong";
}
else
{   $insert=mysql_query("insert into login values('".$fname."','".$lname."','".$mail."','".$password."','".$affiliation."')") or die(mysql_error());}
?>

我想把这个好的或错误的值返回给js。怎么做?

xhr.onload=function()
{
 if (xhr.status==200) 
 {
  alert(xhr.response);
 }else
 {
  alert("unknown server error");
 }
}

如果服务器发送一个响应代码,javascript会将该代码传输到文本中,效果会更好。例如:

onload=function()
{
 switch(xhr.response)
 {
  case "0":{alert("unknown error")};break;
  case "1":{alert("email is already used")};break;
  ...
 }
}

我认为很清楚

我没有代表发表评论,或者我会询问详细信息,但如果你可以考虑使用ajax,它可能看起来像这样:

php:

$doit = //your query;
if($doit){
$youdid = 'ok';
}
else{
exit('1');
}

js:

$(document).ready(function () {
            var foo = $("#formfield")val();
            $.ajax({
                "foo":foo;
                type: 'POST',
                url: 'some.php',
                success: function(responseText) { 
if(responseText == "1") {
alert("Leave instantly");
};
}
else {
alert("One of us");
}

如果您想向JavaScript返回ok或error以进行处理,您可以在registration.php页面中执行以下操作:

 $q=mysql_query("select password  from login where mail='".$mail."' ");
 $pp=mysql_fetch_row($q);
   if($pp[0]=$password){ 
     header('Content-Type: application/json');
         echo json_encode(array('password' => 'ok'));
   }else{ 
     header('Content-Type: application/json');
         echo json_encode(array('password' => 'wrong'));
   }

我还没有完全测试过这一点,但我们的想法是将头设置为返回json,然后向它发送一个json字符串。

这有道理吗?

就像我在下面的评论中所说的,我只使用了jQuery for AJAX。但以下是我对XMLHttpRequest的一些了解,以及我对如何测试返回的内容的理解。

您可以为返回onreadystatechange的响应设置监听器,然后将响应放入变量var pass = xhr.response中,然后将文本输出到alert框(如alert(pass.password))中。

if (xhr.onreadystatechange === 4 && xhr.status === 200){
    var pass = xhr.response;
    //should output either ok or wrong
    alert(pass.password);
}

点击此处阅读有关XMLHttpRequest的更多信息

如果可行,请告诉我。