在使用JSON / PHP时我是新手。我一直试图根据这个答案让这个工作。
How to generate .json file with PHP?
我正在尝试查询MySQL数据库以JSON格式输出它而不将其写入新文件。 file.json因为我正在提取动态数据。我可以创建一个创建json数组的脚本,但是我需要JSON格式的输出。我在下面的示例链接中使用的脚本连接到数据库但是,它没有填充数据。它只是给了我这个输出。我添加了数据库连接检查以检查脚本是否连接到数据库。
成功连接{"流媒体":[]}
这是我目前正在使用的代码。有没有人可以告诉我我缺少什么,可以改进。出于安全原因删除了DB信息。
<?php
header('Content-type:application/json;charset=utf-8');
//Make connection to database
$db=new PDO('mysql:dbname=streamdb;host=localhost;','root','');
// Check connection
if ($db->connect_error) {
die("Connection failed: " . $db->connect_error);
}
echo "Connected successfully";
//Prepare the query for analyzing
$sql=$db->prepare('select * from maintable');
$response = array();
$streamers = array();
$result=mysql_query($sql);
while($sql=mysql_fetch_array($result))
{
$displayname=$row['DisplayName'];
$streamkey=$row['StreamKey'];
$streamers[] = array('DisplayName'=> $displayname, 'StreamKey'=> $streamkey);
}
$response['streamers'] = $streamers;
echo stripslashes(json_encode($response));
?>
-Thanks!
答案 0 :(得分:2)
首先,仅使用PDO。没有mysql_ *函数。
然后你的代码应该是这样的:
$pdo = new PDO('mysql:host=...', 'username', 'password', [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
]);
$result = $pdo->query('SELECT DisplayName, StreamKey FROM ...');
$rows = $result->fetchAll(PDO::FETCH_ASSOC);
header('Content-Type: application/json;charset=utf-8');
echo json_encode(['streamers' => $rows],
JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_NUMERIC_CHECK);
PDO::ERRMODE_EXCEPTION
将PDO设置为将所有错误作为异常抛出,因此可以以简单一致的方式处理它们。
PDO::FETCH_ASSOC
设置fetchAll()
将行返回为数组,其中列名用作数组键。
json_encode()
将负责生成有效的JSON输出。由于您没有将JSON嵌入到HTML中,因此不需要转义斜杠,我们将使其更好地缩进以便于调试。
答案 1 :(得分:0)
正如我在评论中所说,问题可能是&#34; $ row&#34;未初始化。应该是:
while($row=mysql_fetch_array($result))
此外,您使用了与PDO不兼容的mysql_函数。您应该使用$db->query
。
当你提出建议时,我可能会给你一个技巧。
我认为只需检索一个基本上是查询结果内容的表(在$ result中)就有很多代码。我猜你几乎每个请求都有类似的代码。所以我的一般做法是构建一个名为extractResult
的通用函数,它直接从查询结果中生成一行数组。
这是功能:
/**
* Extract a php array from the result of a db query.
* This result can be directly parsed in JSON for instance.
*/
function extractResult($res) {
$arr = array();
while($line = $res->fetch()) {
$count = count($line)/2;
for ($i=0; $i<$count; $i++) {
unset($line[$i]);
}
array_push($arr, $line);
}
return $arr;
}
注意:for循环使用&#34;取消设置&#34;用于删除带数字的条目。抓取返回的是:
Array("DisplayName" => "Loulou", 0 =>"Loulou", "StreamKey" => 12, 1 => 12)
因此它删除了数字副本。
所以你可以像这样使用它,你的代码变得更轻:
<?php
header('Content-type:application/json;charset=utf-8');
//Make connection to database
$db=new PDO('mysql:dbname=streamdb;host=localhost;','root','');
// Check connection
if ($db->connect_error) {
die("Connection failed: " . $db->connect_error);
}
echo "Connected successfully";
$result=$db->query('select display_name AS DisplayName, stream_key AS StreamKey from maintable');
$response = array();
$response['streamers'] = extractResult($result);
echo json_encode($response);
?>
请注意,您必须在请求中直接指定所需的列名称! :)
不知道它是否有趣,但我总是使用这个技巧,因此从DB构建JSON变得更加容易和轻松。祝你好运。
答案 2 :(得分:0)
您可以在这里查看工作代码
<?php
$con=mysqli_connect($servername,$username,$password,$databasename);
if (mysqli_connect_errno())
{
echo "Connection Error" . mysqli_connect_error();
}
$query = "SELECT * FROM TableName";
$result = mysqli_query($con,$query);
$querydata = array();
while($data = mysqli_fetch_array($result)) {
$querydata[] = $data;
}
echo json_encode($querydata);
mysqli_close($con);
?>