【发布时间】:2017-02-15 21:24:40
【问题描述】:
我只是做一个简单的 POST,但由于某种原因,无论我做什么,我都无法读取 JSON 数据
$.ajax({
url: 'server/account/session',
type: 'POST',
data: { "username": name, "password": password} ,
contentType: 'application/json; charset=utf-8',
dataType: "json",
success: function (data) {
sessionStorage.accessToken = data["token"];
sessionStorage.userid = data["userid"];
alert ( sessionStorage.accessToken );
},
error: function () {
}
});
data: {"username": "chips", "password": "potato"}
我的 php:
$result = json_decode($app->request->getBody(), true);
var_dump($result);
将导致 NULL。我不明白为什么它会返回NULL,我发送了一个json然后在php中将它解码为一个。数组,这不是我在做什么吗?
问题二: 2)一个相关的问题:
如果我通过 jquery.post 发送
jQuery.post("server/account/session", { "username": name, "password": password}, function(data){
var result = JSON.parse(data);
sessionStorage.accessToken = result["token"];
sessionStorage.userid = result["userid"];
alert ( sessionStorage.accessToken );
});
并通过 php 在 php 中接收它
$userid = $app->request->params('username');
它工作得很好,但我的问题是,我认为当我们进行 POST 时,数据是通过正文而不是标题发送的。当我做 jquery.post 时,我怎么能通过应用程序的 request->params 收到它??
编辑:
好的,我解决了这个问题。即使您将内容类型指定为 Json,结果也会如此。这并不意味着它将数据转换为 JSON。我必须对数据执行 JSON.stringify。
但是有人可以帮我解决第二个问题吗?
【问题讨论】:
-
当您说“我遇到错误”时,您遇到了什么样的错误?
-
500 内部服务器错误。我用萤火虫检查,它给了我很长的响应,但我认为关键是“非法字符串偏移'用户名'”我应该把整个东西粘贴到这里吗?
-
对于第二个问题,我认为这正是 SLIM 的工作方式。这是易用性的一部分,该请求对象包含 POST 或 GET 数据,而您不必担心太多。有点像 PHP 的 $_REQUEST 变量。
-
这样做有什么坏处吗?据我了解,SSL 应该保护标题和正文吗?谢谢
-
完全没有。你永远不想在 url 中传递敏感信息,但只要你通过 POST 传递它,你就安全了。