PHP接口需设Content-Type为application/json并避免输出干扰,JSON请求须读php://input,跨域需正确处理OPTIONS预检,参数应过滤校验,数据库操作禁用SQL拼接。

PHP 接口必须返回 JSON 且设置正确 Content-Type
前端(尤其是 Fetch 或 Axios)默认期望收到 application/json 响应,如果 PHP 只用 echo json_encode($data) 而不设头,前端可能解析失败或触发 CORS 预检异常。
实操建议:
GarbageSort垃圾识别工具箱是一个基于uni-app开发的微信小程序,使用SpringBoot2搭建后端服务,使用Swagger2构建Restful接口文档,实现了文字查询、语音识别、图像识别其垃圾分类的功能。前端:微信小程序 采用 uni-app 开发框架,uni-app 是一个使用 Vue.js 开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、H5、以及各
- 始终在输出前调用
header('Content-Type: application/json; charset=utf-8'); - 避免任何额外输出:确保文件无 BOM、前后无空行、无
var_dump()或print_r()残留 - 统一用
http_response_code(200)或对应状态码(如 400/401/500),前端可据此分支处理 - 示例最小安全响应:
header('Content-Type: application/json; charset=utf-8');
http_response_code(200);
echo json_encode(['code' => 0, 'msg' => 'success', 'data' => ['id' => 123]], JSON_UNESCAPED_UNICODE);
接收前端参数要区分请求方法和编码方式
GET 参数走 $_GET,POST 表单(application/x-www-form-urlencoded)走 $_POST,但 Fetch/Axios 默认发的是 application/json —— 此时 $_POST 为空,必须手动读取原始输入。
常见错误现象:前端发了 JSON 数据,PHP 却收不到任何值,$_POST 是空数组。
立即学习“PHP免费学习笔记(深入)”;
实操建议:
- 判断请求类型:
$_SERVER['REQUEST_METHOD'] === 'POST' - 检测是否为 JSON 请求:
strpos($_SERVER['CONTENT_TYPE'], 'application/json') !== false - 读取并解码:
$raw = file_get_contents('php://input'); $data = json_decode($raw, true); - 兼容表单和 JSON 的简易封装(可复用):
$input = $_POST;
if (empty($_POST) && strpos($_SERVER['CONTENT_TYPE'], 'application/json') !== false) {
$raw = file_get_contents('php://input');
$input = json_decode($raw, true) ?: [];
}
跨域问题不能只靠 header('Access-Control-Allow-Origin: *')
简单 GET 请求加 Access-Control-Allow-Origin: * 能跑通,但一旦前端带认证(credentials: true)、自定义 Header(如 X-Token)或用 PUT/DELETE 方法,浏览器会先发 OPTIONS 预检请求 —— 此时若后端没响应预检,接口直接被拦在浏览器层,PHP 代码根本不会执行。
实操建议:
- 必须响应 OPTIONS 请求:
if ($_SERVER['REQUEST_METHOD'] === 'OPTIONS') { http_response_code(200); exit; } - 允许凭据时,
Access-Control-Allow-Origin不能为*,需指定具体域名(如https://your-fe.com) - 明确声明允许的 Header 和方法:
header('Access-Control-Allow-Headers: X-Token, Content-Type');、header('Access-Control-Allow-Methods: GET, POST, PUT, DELETE, OPTIONS'); - 把跨域逻辑抽成公共前置脚本(如
cors.php),所有接口开头require_once 'cors.php';
不要在接口里直接操作 $_GET/$_POST 做业务逻辑
裸用超全局变量容易引入安全漏洞(如 SQL 注入、XSS)、类型混淆(字符串 ID 当整数用)、缺失校验(前端绕过 JS 校验直接调用)。
实操建议:
- 统一用白名单方式提取参数:
$id = filter_input(INPUT_GET, 'id', FILTER_VALIDATE_INT) ?: 0; - 对敏感操作强制验证身份:检查
AuthorizationHeader 中的 token,并解析验证(别手写 JWT 解码) - 数据库交互必须用 PDO 预处理或 ORM,禁用拼接 SQL
- 返回前过滤敏感字段(如密码、token 字段),哪怕数据库没查出来也要显式 unset
复杂点往往不在语法,而在边界:前端可能传空字符串、负数 ID、超长字符串、非法 JSON 结构——这些都要在接口入口就拦截,而不是让业务逻辑崩溃后才报 500。










