
本文介绍如何修改 php 脚本,将 post 提交的 json 数据动态拆分为多个独立文件,并为每个文件生成唯一名称(如随机数、时间戳或自定义前缀),避免覆盖,确保数据可追溯。
本文介绍如何修改 php 脚本,将 post 提交的 json 数据动态拆分为多个独立文件,并为每个文件生成唯一名称(如随机数、时间戳或自定义前缀),避免覆盖,确保数据可追溯。
在实际 Web 开发中,常需将客户端提交的结构化数据(如表单数组、配置项集合)持久化为多个独立 JSON 文件,而非单一文件。原始代码仅固定写入 data.json,导致每次请求均覆盖前次内容。要实现“一次请求生成多个不同名称的 JSON 文件”,核心在于:动态构造文件名 + 循环/批量写入逻辑。
以下是一个健壮、可扩展的实现方案:
✅ 正确做法:支持多文件生成的 PHP 示例
<?php
// 1. 安全获取并验证输入
if (!isset($_POST['donnee']) || !is_array($_POST['donnee'])) {
die('Error: Missing or invalid "donnee" data.');
}
// 2. 对每组数据单独处理并保存为独立文件
$baseData = $_POST['donnee'];
// 若 $baseData 是一维数组(如多个对象),可逐个编码;若为二维数组(如多个配置块),建议遍历
foreach ($baseData as $index => $item) {
// 清理与格式化单条数据(沿用原逻辑,但作用于单个 item)
$json = json_encode($item, JSON_PRETTY_PRINT);
$cleaned = str_replace("\", "", $json);
$cleaned = str_replace(""{", "", $cleaned);
$cleaned = str_replace("}"", "", $cleaned);
$cleaned = str_replace('""type', '"type', $cleaned);
$cleaned = str_replace(']"', ']', $cleaned);
$cleaned = '{' . $cleaned . '}';
// 3. 生成唯一文件名(推荐组合方式:前缀 + 时间戳 + 随机数 + 序号)
$prefix = 'config_';
$timestamp = date('Ymd_His');
$random = sprintf('%04d', rand(0, 9999));
$filename = $prefix . $timestamp . '_' . $random . '_' . $index . '.json';
// 4. 写入文件(含错误处理)
$fp = fopen($filename, 'w');
if ($fp === false) {
error_log("Failed to open file: $filename");
continue;
}
if (fwrite($fp, $cleaned) === false) {
error_log("Failed to write to file: $filename");
}
fclose($fp);
echo "✅ Saved: $filename<br>";
}
?>⚠️ 关键注意事项
- 安全性提醒:原始代码中的 str_replace 链存在风险,可能破坏合法 JSON 结构(如误删转义引号)。更安全的做法是避免字符串替换,直接对原始数组进行校验与规范化处理,再 json_encode。
- 文件名唯一性:仅用 rand(0,1000) 易冲突,尤其高并发场景。应优先使用 uniqid() 或 date('YmdHis') . rand(1000,9999) 组合。
- 目录权限与路径:确保 PHP 进程对目标目录有写权限;生产环境建议指定绝对路径(如 __DIR__ . '/exports/' . $filename),并预先创建目录。
- 数据结构适配:上述示例假设 $_POST['donnee'] 是一个数组(如 [{}, {}, {}])。若实际为单个对象需拆分,请先解析其内部结构(例如按 key 分割)。
✅ 推荐增强实践
- 添加文件写入后校验:file_get_contents($filename) + json_decode(..., true) 确保内容可解析;
- 记录日志:将生成的文件名、时间、数据摘要写入 audit.log;
- 返回 JSON 响应:替代 HTML 输出,便于前端统一处理(如 json_encode(['files' => $generatedList]))。
通过以上改造,即可稳定、安全、可维护地实现“一次提交 → 多个唯一命名 JSON 文件”的业务需求。











