0

$jsonstring をエコーすると、要求したオブジェクトを含む空白の HTML ページ全体が (PHP から Javascript に) 送信されたように見えます。ここら辺はとても新しいので、理由がわかりません。

私のPHPコード:

<?php

//ini_set('display_errors', '1');
//ini_set('error_reporting', E_ALL);

require "localdbcxn.php";

$encoded = file_get_contents('php://input');
$decoded = json_decode($encoded, true);

$email = $decoded['email'];
$password = $decoded['password'];
$identify = mysql_query("SELECT UserId FROM users WHERE UserEmail='$email' AND UserPassword='$password'");
$numrows = mysql_num_rows($identify);
$row = mysql_fetch_assoc($identify);
$userid = $row['UserId'];

$sessionid = mt_rand(1111111111111111,9999999999999999);
$sessionkey = mt_rand(1111111111111111,9999999999999999);
$logindate = date("Y-m-d H:i:s");


$login = "INSERT INTO mobileSession (UserId, SessionId, SessionKey, BeginDate) VALUES('$userid','$sessionid','$sessionkey','$logindate') ON DUPLICATE KEY UPDATE  SessionId='$sessionid', SessionKey='$sessionkey', BeginDate='$logindate' ";

if ($numrows == 1) {
  mysql_query($login);
  $session = array('UserId'=>$userid,'SessionId'=>$sessionid);
  $jsonstring = json_encode($session);
  echo $jsonstring;
}
?>

コンソール(ログ)に表示される内容は次のとおりです。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
  <title>Untitled Document</title>
</head>

<body>
</body>
</html>{"UserId":"33","SessionId":8207219793564744}

UserID から ...4744 までは正しいですが、html コードがエコーされている理由を理解できる人はいますか? 私の限られた経験では、これまで見たことがなく、何か間違ったことをしていると感じています。

ありがとう!

4

1 に答える 1

0

json データを出力する前にコンテンツ タイプを指定する必要があります。エコー セット ヘッダーの前 -

header('Content-type: application/json');
于 2013-09-22T05:26:40.220 に答える