我主要在玩PHP和cURL(代码也包括一些AJAX和HTML)。

建筑:

正面中间背面 MySQL

描述:


在我的前一节中,我将创建一个AJAX对象,并使用从HTML表单中获取的一些数据(JSON格式)进行POST请求。
数据发送到我的中间服务器(PHP文件)。该文件接收它并对其进行json_decode。确定要使用的巫婆开关大小写,并使用cURL将其发送到后台服务器。
后台服务器(PHP文件)从POST请求获取数据,并且它对数据进行json_decode。然后,如果密码匹配,它将继续创建MySQL连接检查。如果密码匹配,它将回显一个字符串“ GRATNED”。
数据传递回中间服务器,然后传递到AJAX接收数据并显示字符串的前部。


所以...

所有这些都完美。但是,由于某种原因,我的数据末尾包含1。这弄乱了我的JS文件中的正则表达式。

你们能否让我知道我必须修改cURL的选项(如果是这种情况),或者我正在做什么,我得到那个one(1)以及如何将其删除。

感谢大伙们。

附上我的代码和输出图像...

面前

function whenSubmitt()
{
  //Get the data that I want to pass
  //JS Object
  var parameters = {"case":"login",
  "username":document.getElementById("username").value,
  "password":document.getElementById("password").value
  };

  //Make into JSON object
  parameters = JSON.stringify(parameters);

  //Create AJAX object
  var xobj = new XMLHttpRequest();
  var method = "POST";
  var url = "./front.php";

  //Open Connection
  xobj.open(method,url,true);
  xobj.setRequestHeader("content-type", "application/x-www-form-urlencoded");

  //When Submit button is pressed
  xobj.onreadystatechange = function()
  {
    if (xobj.readyState == 4 && xobj.status == 200)
    {
      var respuestas = xobj.responseText;
      document.getElementById("msrv_answer").innerHTML = respuestas;
      //window.location.replace(respuestas[0]); //REDIRECTS TO NEW PAGE
    }
  };


  xobj.send(parameters);
}


前置PHP

<?php

function contact_middle_man($parameters)
{
 $url = "https://myurl/middle/middle.php";

 $obj = curl_init();
 curl_setopt($obj, CURLOPT_URL, $url);
 curl_setopt($obj, CURLOPT_POST, strlen($parameters));
 curl_setopt($obj, CURLOPT_POSTFIELDS, $parameters);
 curl_setopt($obj, CURLOPT_RETURNTRANSFER, true); //ALLOWS TO GET ANSWER BACK IN STRING FORMAT, AND DOES NOT OUTPUT ANSWER DIRECTLY.

 $ans = curl_exec($obj);

 curl_close($obj);

 return $ans;
}


/*RECEIVE DATA FROM WEB INTERFACE, USER*/
$indata = file_get_contents("php://input");

/*CONTACT MIDDLE MAN, USE CURL*/
$middle_answ = contact_middle_man($indata);

echo $middle_answ;
?>


中级PHP

<?php

function http_post_back_server($url, $data)
{
    $obj = curl_init();

    curl_setopt($obj, CURLOPT_URL, $url);
    curl_setopt($obj, CURLOPT_POST, strlen($data));
    curl_setopt($obj, CURLOPT_POSTFIELDS, $data);

    $ans = curl_exec($obj);

    curl_close($obj);

    return $ans;
}

/*URL TO BACK SERVER*/
$url_myserver = "https://myurl/loginquery_v2_.php";

/*GLOBAL VARS*/
$back_ans ="";

/*RECEIVE DATA FROM POST REQUEST*/
$indata = file_get_contents("php://input");
$data = json_decode($indata, true);


/*MAKE REQUEST TO SERVERS*/
switch($data["case"]){
    case "login":
        $back_ans = http_post_back_server($url_myserver,$indata);
        break;
    default:
        $back_ans="NADA";
        break;
}

/*ANSWER BACK TO FRON END*/
echo $back_ans;

?>


返回PHP

<?php

/*RECEIVING DATA FROM POST REQUEST */
$indata = file_get_contents("php://input");

/*DATA TO JSON OBJ*/
$indata = json_decode($indata, true);


/*CONNECTION TO DATABASE */
$conn=mysqli_connect(myusername, mypassword);

/*CHECKING DATABASE CONNECTIVITY */

if(mysqli_connect_error())
{ echo "Connection Error: ".mysqli_connect_error; }

/*GOOD CONNECTION ... CONTINUE */

$uname = $indata["username"];

$query="SELECT * FROM alpha WHERE username ='".$indata["username"]."'";

$db_output = mysqli_query($conn,$query);

/* CHECK QUERY RESULT */
if($db_output)
{

 /* FETCH RESULTS */
 while($result = mysqli_fetch_assoc($db_output))
 {

  /* COMPARE STORE PWD VS RECEIVED PWD */
  if($result["password"] == $indata["password"])
  {
    /*JSON OBJECT*/
    echo "ACCESS GRANTED";
  }

  /* PASSWORDS DOES NOT MATCH */
  else
  {
    /*JSON OBJECT*/
    echo "ACCESS DENY";
  }

 }
}

/*CLOSE DATABASE CONNECITON */

mysqli_close($conn);

?>


输出页面

javascript - PHP和cURL —奇怪的输出-LMLPHP

感谢大伙们。

最佳答案

发生这种情况是因为在您的中间PHP中,您在curl调用中缺少CURLOPT_RETURNTRANSFER选项。结果,为$ans分配了值true(因为curl调用成功),并且curl调用(ACCESS GRANTED)的输出回显到Middle PHP的输出中,随后是$back_ans ,这是真的,当它被回显时,在输出中生成一个1。因此,返回到Front PHP的字符串为ACCESS GRANTED1。您可以通过将其添加到中间PHP中来解决此问题:

curl_setopt($obj, CURLOPT_RETURNTRANSFER, true);


然后,将为$ans分配值ACCESS GRANTED而不是true,您的输出将如预期的那样。

07-24 09:47
查看更多