json_decode在 godaddy 托管上失败
2022-08-31 01:13:04
我在我的PHP中用于解析来自POST的数据(POST本身是通过ajax执行的)。我的代码如下所示:json_decode
$data = json_decode($_POST['logdata'], true);
if(!$data) {
$ecodes = array(
JSON_ERROR_NONE => "No error has occurred",
JSON_ERROR_DEPTH => "The maximum stack depth has been exceeded",
JSON_ERROR_STATE_MISMATCH => "Invalid or malformed JSON",
JSON_ERROR_CTRL_CHAR => "Control character error, possibly incorrectly encoded",
JSON_ERROR_SYNTAX => "Syntax error",
JSON_ERROR_UTF8 => "Malformed UTF-8 characters, possibly incorrectly encoded"
);
$err = json_last_error();
$result = array("error" => 1, "error_msg" => "Invalid log data: " . $ecodes[json_last_error()]);
echo json_encode($result);
exit;
}
... //use $data array
此代码工作正常。在我的本地Linux机器或Mac上执行时,传递的数据被正确解码并且一切正常。但是,当在godaddy共享主机上执行相同的代码时,解码将失败并显示语法错误。在花费了大量时间试图缩小问题范围之后,我发现当我在JSON对象属性的值中具有或字符时,就会出现问题。<
>
javascript中的上传部分(ajax)看起来像这样:
$.ajax({
url: '/emaillog.php',
type: 'POST',
dataType: 'json',
data: { logdata: JSON.stringify(this.logData[this.scenarioLogId]) },
cache: false,
error: function(jqXHR, textStatus, errorThrown) {
alert("Error occurred during upload: " + textStatus);
},
success: function(data, textStatus, jqXHR) {
var msg = data.error
? "An error occurred processing action log: " + data.error_msg
: "Action log processed successfully.";
alert(msg);
}
})
如您所见,POST 参数的值是使用 在检查时(客户端和服务器端)创建的,并且是正确的。如果重要,下面是已提交 POST 参数的示例值:JSON.stringify
{
"scenarioId":"1",
"scenarioName":"MOH",
"startTime":1355496349,
"log":[
{
"role":"Leader",
"task":"MOH",
"response":"start",
"time":1355496349
},
{
"role":"Head",
"task":"<span class=\"bold\">Assign Role</span>",
"response":"done",
"time":1355496351
}
]
}
如果数组中的最后一个元素(具有任务“分配角色)被删除,则成功处理所有内容。如果我用空格替换并>字符,同样,一切都很好。<
>
由此产生了两个问题:
如果此类 JSON 字符串上的语法错误是正确的行为,那么为什么我在其他两个环境中看不到该错误?另外,为什么生成不正确的字符串?
JSON.stringify
如果此类 JSON 字符串上的语法错误是错误的行为,则 godaddy 的 PHP 实现或配置一定存在问题。
请注意,虽然我明确询问了godaddy,但它只相关,因为它是唯一一个代码产生错误的提供商。任何人都可以对这种情况有所了解吗?