从PHP脚本返回JSON

我想从PHP脚本中返回JSON。

我只是回应结果? 我必须设置Content-Type标题吗?

虽然没有它通常很好,你可以也应该设置Content-Type头:

 <?PHP $data = /** whatever you're serializing **/; header('Content-Type: application/json'); echo json_encode($data); 

如果我不使用特定的框架,我通常允许一些请求参数修改输出行为。 通常为了快速排除故障,通常不用发送头文件,或者有时候打印数据有效载荷(在大多数情况下,它不应该是必须的)。

返回JSON的完整清晰的PHP代码是:

 $option = $_GET['option']; if ( $option == 1 ) { $data = [ 'a', 'b', 'c' ]; // will encode to JSON array: ["a","b","c"] // accessed as example in JavaScript like: result[1] (returns "b") } else { $data = [ 'name' => 'God', 'age' => -1 ]; // will encode to JSON object: {"name":"God","age":-1} // accessed as example in JavaScript like: result.name or result['name'] (returns "God") } header('Content-type: application/json'); echo json_encode( $data ); 

尝试使用json_encode对数据进行编码,并使用header('Content-type: application/json');设置内容typesheader('Content-type: application/json');

根据json_encode手册,该方法可以返回一个非string( false ):

成功时返回JSON编码的string,失败时返回FALSE

当发生这种情况时, echo json_encode($data)将输出空string,这是无效的JSON 。

json_encode的参数包含一个非UTF-8string,将失败(并返回false )。

这个错误条件应该在PHP中捕获,例如:

 <?php header("Content-Type: application/json;charset=utf-8"); // Collect what you need in the $data variable. $json = json_encode($data); if ($json === false) { // Avoid echo of empty string (which is invalid JSON), and // JSONify the error message instead: $json = json_encode(array("jsonError", json_last_error_msg())); if ($json === false) { // This should not happen, but we go all the way now: $json = '{"jsonError": "unknown"}'; } // Set HTTP response status code to: 500 - Internal Server Error http_response_code(500); } echo $json; ?> 

那么接收端当然应该知道jsonError属性的存在表示一个错误条件,应该相应地处理。

在生产模式下,向客户端发送通用错误状态可能会更好,并logging更具体的错误消息以供日后调查。

阅读更多关于处理PHP文档中的 JSON错误的信息 。

使用header('Content-type: application/json');设置内容typesheader('Content-type: application/json'); 然后回显您的数据。

设置访问安全性也很好 – 只需将*replace为您希望能够访问的域即可。

 <?php header('Access-Control-Allow-Origin: *'); header('Content-type: application/json'); $response = array(); $response[0] = array( 'id' => '1', 'value1'=> 'value1', 'value2'=> 'value2' ); echo json_encode($response); ?> 

这里是更多的示例: 如何绕过访问控制,允许来源?

你的问题的答案在这里 ,

它说。

JSON文本的MIME媒体types是application / json。

所以如果你把头部设置为这种types,并输出你的JSONstring,它应该工作。

如果你需要从php发送自定义信息的JSON,你可以添加这个header('Content-Type: application/json'); 之前打印任何其他的东西,那么你可以打印你的客户echo '{"monto": "'.$monto[0]->valor.'","moneda":"'.$moneda[0]->nombre.'","simbolo":"'.$moneda[0]->simbolo.'"}';

如上所述:

 header('Content-Type: application/json'); 

会做这个工作 但请记住:

  • 即使没有使用这个头,Ajax也不会有问题,除非你的json包含一些HTML标签。 在这种情况下,您需要将标题设置为application / json。

  • 确保你的文件不是用UTF8-BOM编码的。 这种格式在文件的顶部添加一个字符,所以你的header()调用将会失败。

这是一个简单的PHP脚本来返回男性女性和用户ID,因为json的值将是任何随机值,你调用脚本json.php。

希望这个帮助谢谢

 <?php header("Content-type: text/json"); $myObj=new \stdClass(); $myObj->user_id = rand(0, 10); $myObj->male = rand(0, 5); $myObj->female = rand(0, 5); $myJSON = json_encode($myObj); echo $myJSON; ?> 

是的,你需要使用echo来显示输出。 Mimetype:application / json

你可以使用这个小小的PHP库 。 它发送标题,并给你一个对象使用它很容易。

看起来像 :

 <?php // Include the json class include('includes/json.php'); // Then create the PHP-Json Object to suits your needs // Set a variable ; var name = {} $Json = new json('var', 'name'); // Fire a callback ; callback({}); $Json = new json('callback', 'name'); // Just send a raw JSON ; {} $Json = new json(); // Build data $object = new stdClass(); $object->test = 'OK'; $arraytest = array('1','2','3'); $jsonOnly = '{"Hello" : "darling"}'; // Add some content $Json->add('width', '565px'); $Json->add('You are logged IN'); $Json->add('An_Object', $object); $Json->add("An_Array",$arraytest); $Json->add("A_Json",$jsonOnly); // Finally, send the JSON. $Json->send(); ?> 

是的,只需设置适当的HTTP头,回显结果,然后退出脚本。

如果您查询数据库并需要JSON格式的结果集,可以这样做:

 <?php $db = mysqli_connect("localhost","root","","mylogs"); //MSG $query = "SELECT * FROM logs LIMIT 20"; $result = mysqli_query($db, $query); //Add all records to an array $rows = array(); while($row = $result->fetch_array()){ $rows[] = $row; } //Return result to jTable $qryResult = array(); $qryResult['logs'] = $rows; echo json_encode($qryResult); mysqli_close($db); ?> 

有关使用jQueryparsing结果的帮助,请参阅本教程 。