所以我想在PHP中编写一个REST API,用于在iPhone上使用JSON以及许多网站和设备。我有以下代码,当通过GET语句访问时,返回如下文件:
1mdi2o3.part
如何返回类似于:users.json
的内容$db->setQuery( "SELECT * FROM users");
$db->query() or die($queryError);
$numRows = $db->getNumRows();
$row = $db->loadObjectList();
// PRINT JSON FILE
header("Content-type: application/json");
for($i = 0 ; $i < $numRows; $i++){
$json_output[$i] = $row[$i];
}
$MYjson_output = json_encode($json_output);
echo $MYjson_output;
答案 0 :(得分:10)
并非完全符合您的目标,但这里有3-4个可能有效的解决方案:
这可能是获取API的干净URI的最常规方法。如果你想让user.json的用户部分是动态的,你可以使用mod_rewrite(再次假设Apache)将你的URL重写为php处理程序脚本。如果您要使用传统的RESTful样式URL路由,您可能仍希望使用此方法来实现干净的/
分隔URL。
# For grabbing all users
RewriteEngine on
RewriteRule ^users\.json rest.php [L]
# For grabbing one particular user
RewriteEngine on
RewriteRule ^([a-z0-9]+)\.json rest.php?user=$1 [L]
其中rest.php是你的PHP处理程序脚本。
如果您不想使用mod_rewrite,您也可以执行类似
的操作example.com/rest.php/users.json
example.com/rest.php/user-id.json
甚至
example.com/rest.php/user-id
example.com/rest.php/user/user-id
其中rest.php是你的PHP处理程序脚本。您可以使用user-id
全局$_SERVER
从URL(或URI,如果我们正在谈论RESTful术语)中获取$_SERVER['REQUEST_URI']
。
我相信您要添加Content-Disposition标题...
<?php
header('Content-Disposition: attachment; filename="users.json"');
?>
这将强制将文件作为user.json下载。这通常不是REST API的预期行为,但从你的问题措辞的方式来看,我想我会把它扔出去。
假设您正在运行Apache服务器,您还可以使用AddHandler
指令将.json
扩展名文件视为php。
AddHandler application/x-httpd-php .json
警告:其他普通的.json文件将被视为PHP,因此您可能希望使用PHP脚本在目录中的.htaccess文件中设置它。这对于这个URI可以正常工作,但如果你暴露了许多URI
则不理想答案 1 :(得分:-2)
欢迎来到SO。您是否考虑过将Zend framework用于此应用程序?我written about this topic before,如果你使用Zend我可能会有额外的帮助。它肯定会帮助你超越基础。
HTH,
-AJ
答案 2 :(得分:-2)
问题在于这一行:
header("Content-type: application/json");
我知道这看起来是正确的方法(毕竟,application/json
是JSON内容的官方MIME类型),但它会导致大多数浏览器向您显示文件下载对话框,当您只想查看文本时。您可以使用text/plain
编码来避免这种情况。请注意,您的AJAX / iPhone / ...应用程序可能并不关心内容类型,因此您的API将适用于这两种情况。
另请参阅this blog post,其中提供了更多背景信息。