本教程旨在解决php脚本无法正确接收javascript fetch api发送的post请求数据的问题。核心在于理解post数据通过请求体而非url查询字符串传输,并指导php如何正确使用$_post超全局变量来获取这些数据,同时强调数据安全与最佳实践。
在现代Web开发中,客户端(通常是浏览器中的JavaScript)与服务器端(如PHP)之间的数据交互是构建动态应用的基础。fetch API是JavaScript中用于发起网络请求的强大工具,它支持多种HTTP方法,包括POST,用于向服务器提交数据。然而,开发者在使用fetch发送POST请求时,PHP端有时会遇到无法正确读取数据的困惑。
当JavaScript使用fetch API发起一个POST请求时,数据通常通过HTTP请求的请求体(Request Body)传输,而不是通过URL的查询字符串。这与GET请求不同,GET请求的数据会附加在URL的末尾作为查询参数。
例如,以下JavaScript代码片段展示了如何使用fetch发送一个POST请求,并将数据编码为application/x-www-form-urlencoded格式:
function insertNewRecord(data) {
fetch('/configs/database/add.php', {
method: 'POST',
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
},
body: `name=${data.name}&contact=${data.contact}&delivery=${data.delivery}&value=${data.value}`
})
.then(function(response) {
if (response.ok) {
return response.text();
}
throw new Error('Error in the request.');
})
.catch(error => console.error('Fetch error:', error));
// 后续的DOM操作与数据发送无关,此处省略
// var table = document.getElementById("employeeList").getElementsByTagName('tbody')[0];
// ...
}在这段代码中:
PHP提供了几个超全局变量来访问HTTP请求中的数据,其中最常用的是:
原始的PHP代码尝试通过解析当前请求的URL来获取POST数据:
query($sql); ?>
问题在于,当JavaScript fetch使用POST方法发送数据时,$_SERVER['REQUEST_URI']中的query部分通常是空的,因为数据被放置在请求体中。因此,parse_str($parts['query'], $query) 会导致$query数组为空,进而访问$query['name']等会返回undefined或引发错误。
要正确接收通过POST请求发送的application/x-www-form-urlencoded数据,PHP应该直接使用$_POST超全局变量。
以下是修正后的PHP代码示例:
'All fields are required.']);
exit;
}
// 建立数据库连接
$conn = OpenCon();
if (!$conn) {
http_response_code(500); // Internal Server Error
echo json_encode(['error' => 'Database
connection failed.']);
exit;
}
// 使用预处理语句防止SQL注入(非常重要!)
$stmt = $conn->prepare("INSERT INTO users (name, contact, delivery, value) VALUES (?, ?, ?, ?)");
if ($stmt === false) {
http_response_code(500);
echo json_encode(['error' => 'Failed to prepare statement: ' . $conn->error]);
$conn->close();
exit;
}
// "ssss" 表示四个字符串类型参数
// 根据实际数据类型调整绑定参数类型,例如 "isds" 表示 int, string, double, string
$stmt->bind_param("ssss", $name, $contact, $delivery, $value);
if ($stmt->execute()) {
echo json_encode(['message' => 'Record inserted successfully.']);
} else {
http_response_code(500); // Internal Server Error
echo json_encode(['error' => 'Failed to insert record: ' . $stmt->error]);
}
$stmt->close();
$conn->close();
} else {
http_response_code(405); // Method Not Allowed
echo json_encode(['error' => 'Only POST requests are allowed.']);
}
?>关键改进点:
正确处理JavaScript fetch POST请求在PHP中的数据接收,关键在于理解HTTP协议中POST数据是通过请求体传输的,并利用PHP提供的$_POST超全局变量来获取这些数据。同时,为了构建健壮和安全的Web应用,务必实施严格的数据验证、使用预处理语句防止SQL注入,并提供完善的错误处理机制。遵循这些最佳实践,将大大提高应用的可靠性和安全性。