【发布时间】:2014-05-12 22:37:24
【问题描述】:
我正在试用 Redis,并想构建一个简单的前端/后端设置来测试和练习。前端是 HTML / Javascript / JQuery,后端是 PHP / Apache / Redis。基本上,我想向后端发送一个发布请求并接收响应,然后我会在 Web 控制台上显示该响应。为了发送请求,我使用了 JQuery:
var data = $("#login_form :input").serializeArray();
var username = data[0]['value'];
var password = data[1]['value'];
$.ajax({
type: "POST",
url: "http://localhost/Convo/user.php?jsoncallback=%3F",
dataType: "json",
cache: false,
data: { username: username, password: password, method: "create" },
success: function(text){console.log("awesome");}
});
我在 Firefox 上使用 Firebug 来查看实际情况。在 Firebug 中,我看到一个 GET 请求被触发而不是一个 POST。附加到 url 的 jsoncallback 字符串可能是原因,但没有它,我根本没有得到响应。作为旁注,我期待 json 回复。这是我的 PHP 代码:
error_reporting(E_ALL);
ini_set('display_errors', '1');
require 'Predis/Autoloader.php';
Predis\Autoloader::register();
$body = array();
$head = array();
$redis = new Predis\Client(array(
'scheme' => 'tcp',
'host' => '127.0.1.1',
'port' => 6379,
));
if(!$redis)
{
$body['status'] = "fail";
$body['message'] = "unable to connect to database";
$head['body'] = $body;
header('Content-type: application/json');
echo json_encode($head);
exit;
}
else
{
$body['status'] = "success";
$body['message'] = "connected to database!";
$head['body'] = $body;
$jsoncallback = $_POST['jsoncallback'];
header('Content-Type: application/json');
echo $jsoncallback . '(' . json_encode($head) . ')';
exit;
}
jsoncallback 是获得响应的唯一方法,但是没有它我如何成功启动真正的 POST 请求?
【问题讨论】:
-
你为什么要设置那个get参数?您的脚本中似乎不需要它
-
无法使用 jsonp 数据类型进行 POST。
-
根据我在另一个问题上找到的答案,从 PHP 返回的数据必须由通过 get 发送的 jsoncallback “包装”。没有所有 jsoncallback 的东西,请求被触发但没有任何返回
-
我使用“文本”作为我的帖子的数据类型,但您可能需要 json,而不是 jsonp
-
我改成json了,还是改成GET请求。
标签: javascript php jquery ajax json