ホームページ  >  記事  >  バックエンド開発  >  php配列をjsonに変換する際に関連する問題があります。ぜひご覧ください。

php配列をjsonに変換する際に関連する問題があります。ぜひご覧ください。

WBOY
WBOYオリジナル
2016-06-13 12:10:30977ブラウズ

図に示すように、php 配列の json への変換に問題があります。

を見てください:


何か出力しますか?

echo json_encode($result);#输出结果

個人的には、$data の配列要素が Client オブジェクトであり、json に変換する際に何らかの問題が発生したのではないかと考えています。しかし、何が問題なのか、どのように変換すればよいのかわかりません。それとも他の変換方法があるのでしょうか?
class Result {<br />		var $state;<br />		var $data = array();<br />	}

完全なコード:
$start = 0;
$end = 2;
$uid = 1;
$result = new Result();
$result_set = getClients($start, $end, $uid);
$data = array();
$count = 0;

while($row = mysql_fetch_array($result_set)) {
$client = new Client();
$client->cid = $row['id'];
$client->gender = $row['gender'];
$client->rank = $row['rank'];
$client->name = $row['name'];
$client->phoneNum = $row['phoneNum'];
$client->email = $row['email'];
$client->address = $row['address'];
$result->data[$count] = $client;

echo $result->data[$count]->cid." ";
echo $result->data[$count]->gender." ";
echo $result->data[$count]->rank." ";
echo $result->data[$count]->name." ";
echo $result->data[$count]->phoneNum." ";
echo $result->data[$count]->address."\n";

$count++;
}

if(count($data) > 0) {
$result->state = 0;
} else {
$result->state = 1;
}

echo json_encode($result);#输出结果

class Result {<br /> var $state;<br /> var $data = array();<br /> }

出力結果:
---------- debug php ----------<br /><br />Deprecated: mysql_connect(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in D:\WWW\wsd\trunk\src\server\api\db\init_db.php on line 10<br /><br />Deprecated: mysql_connect(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in D:\WWW\wsd\trunk\src\server\api\db\init_db.php on line 10<br />3  0  经理  张小莉  18825044888  广东省广州市天河区<br />4  0  主管  吴美凤  18576430777  广东省深圳市南山区蛇口南海大道1079号<br />PHP Deprecated:  mysql_connect(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in D:\WWW\wsd\trunk\src\server\api\db\init_db.php on line 10<br />PHP Deprecated:  mysql_connect(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in D:\WWW\wsd\trunk\src\server\api\db\init_db.php on line 10<br /><br />Output completed (0 sec consumed) - Normal Termination


次の形式のような出力があるはずです:
{"state":1,<br />"data":[<br />           {"cid":3,<br />          "gender":0,<br />          "rank":"经理"<br />          "name":" 张小莉"<br />          "phoneNum":"18825044888  "<br />          "address":"广东省广州市天河区"},<br />          {"cid":4,<br />          "gender":0,<br />          "rank":"主管"<br />          "name":" 吴美凤"<br />          "phoneNum":"18576430777  "<br />          "address":" 广东省深圳市南山区蛇口南海大道1079号"}<br />          ]<br />}


何が問題ですか?どうやって解決すればいいでしょうか?ありがとう!





-----ソリューションアイデア-------------- -------
print_r($result);
何が見えますか?
------解決策のアイデア----------------------
クラス Result のオブジェクトを変換できませんでした文字列オブジェクトを文字列に変換できません
この場合、もちろん json にすることはできません
クライアント クラスの定義を確認してください
-----解決策----- -- ----------------
価値がないかもしれません

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。