【发布时间】:2016-03-29 18:06:57
【问题描述】:
我有一个表格来注册一个有 N 个参与者的项目。
我现在被要求添加一个字段,每个参与者必须发送他们的学校证书。
问题是,在对象中添加此字段后,我无法再将数据发送到 PHP。
我必须发送的 JSON 格式如下:
{
"description": [STRING],
"name": [STRING],
"objective": [STRING],
"participants": [NUMBER],
"regulament": [BOOLEAN],
"resume": [STRING],
"users": {
"1": {
"born": [DATE],
"educationCertificate": [OBJECT], // File
"email": [STRING],
"genre": [BOOLEAN],
"level": [NUMBER],
"name": [STRING],
"neighborhood": [STRING],
"phone": [STRING],
"school": [STRING],
"socialNumber": [STRING]
},
. . .
"n": {
"born": [DATE],
"educationCertificate": [OBJECT (FILE)],
"email": [STRING],
"genre": [BOOLEAN],
"level": [NUMBER],
"name": [STRING],
"neighborhood": [STRING],
"phone": [STRING],
"school": [STRING],
"socialNumber": [STRING]
}
}
}
要发送文件,我的 $http 如下所示:
$http({
method: "POST",
url: [SCRIPT],
headers: {
"Content-Type": undefined
},
data: $scope.data,
transformRequest: function (data) {
var formData = new FormData();
angular.forEach(data, function (value, key) {
formData.append(key, value);
});
return formData;
}
}).success(function(response) {
// do something
});
在 PHP 中,这是我检索 AngularJS 发送的数据的函数:
function param() {
$array = array();
$request = new stdClass();
if (count($_GET) || count($_POST) || count($_FILES)) {
$request = json_decode(json_encode(array_merge($_GET, $_POST, $_FILES)), false);
} else {
$request = json_decode(file_get_contents("php://input"));
}
if ($request) {
$array = array_filter(array_map(function($data) {
return is_string($data) ? trim($data) : $data;
}, get_object_vars($request)), function($data) {
return is_string($data) ? strlen($data) : $data;
});
}
return json_decode(json_encode($array), false);
}
/* In the script */
$request = param();
然而,PHP 中传入的数据如下:
{
"description": [STRING],
"name": [STRING],
"objective": [STRING],
"participants": [NUMBER],
"regulament": [BOOLEAN],
"resume": [STRING],
"users": [STRING] // "[object Object]"
}
我一直使用"Content-Type": undefined,但我尝试使用"Content-Type": "multipart/form-data" 和"Content-Type": "application/x-www-form-urlencoded;"。但结果更糟。
有人知道如何解决这个问题吗?
【问题讨论】:
-
您可以使用
readAsDataURL(),就像SO question 中提到的那样。还有一个Polyfill 来改进浏览器支持。