0

0

API接口怎么开发_PHP RESTful API创建【指南】

雪夜

雪夜

发布时间:2026-03-16 17:40:44

|

791人浏览过

|

来源于php中文网

原创

用PHP快速搭建RESTful路由需配置Web服务器重写规则(Nginx加try_files,Apache启用mod_rewrite),统一解析REQUEST_URI获取路径,手动读php://input处理JSON等非表单数据,显式设置HTTP状态码和Content-Type,采用Bearer Token无状态鉴权,严格区分401/403/422等错误状态。

api接口怎么开发_php restful api创建【指南】

怎么用 PHP 快速搭一个能跑的 RESTful 路由

PHP 本身不带原生 REST 路由,得靠手动解析 $_SERVER['REQUEST_METHOD']$_SERVER['PATH_INFO'](或 $_GET['route']),别指望 index.php/user/123 自动映射——Web 服务器默认不会把路径透传给 PHP,得配 rewrite 规则。

常见错误是直接访问 api.php/user/123 报 404,其实是 Apache/Nginx 没配好,不是 PHP 写错了。

  • Nginx 需加 try_files $uri $uri/ /api.php?$args,否则路径里的 /user/123 根本进不到 PHP
  • Apache 要启用 mod_rewrite,且 .htaccess 里写 RewriteRule ^(.*)$ api.php [QSA,L]
  • PHP 入口统一用 parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH) 提取路径,别硬切 $_SERVER['PATH_INFO']——它在 CGI/FastCGI 下常为空

POST/PUT/DELETE 数据收不到?检查 php://inputContent-Type

前端发 application/json,PHP 不会自动解析到 $_POST,必须手动读 php://inputjson_decode()。这是最常卡住的点,报错往往是“空数组”或“undefined index”。

另外,$_POST 只收 application/x-www-form-urlencodedmultipart/form-dataapplication/jsontext/xml 这类都得自己读流。

立即学习PHP免费学习笔记(深入)”;

  • $raw = file_get_contents('php://input') 获取原始体,再判断 $_SERVER['CONTENT_TYPE'] 类型
  • PUTDELETE 请求在部分 Nginx 配置下会被转成 GET,检查 fastcgi_pass_request_headers on; 是否开启
  • 别在 $_POST 里找 JSON 字段——它根本不在那儿

状态码和 Content-Type 别靠默认值

PHP 默认输出 200 OK + text/html,但 REST API 必须显式设状态码和类型,否则前端 fetch().json() 会因 MIME 不匹配抛错。

阿里妈妈·创意中心
阿里妈妈·创意中心

阿里妈妈营销创意中心

下载

比如返回错误时只 echo {"error":"not found"},没设 404 状态码,前端可能当成成功处理。

  • http_response_code(404) 设状态,别只 echo 数字
  • 响应 JSON 一定要 header('Content-Type: application/json; charset=utf-8'),少个分号或空格都可能让某些客户端解析失败
  • 不要在 header() 前有任何输出(包括空行、BOM),否则报 “headers already sent”

简单鉴权别碰 session,优先用 Bearer Token 解析

REST 是无状态的,PHP 的 session_start() 会强制写 cookie、依赖服务端存储,和 REST 原则冲突。真要鉴权,就用 Header 里的 Authorization: Bearer xxx,自己解析验证。

容易踩的坑是混淆了“登录接口返回 token”和“后续请求带 token”的逻辑——token 验证必须每请求都做,不能只在登录时校验一次。

  • getallheaders()$_SERVER['HTTP_AUTHORIZATION'] 取 token,注意 Apache 下后者可能为 $_SERVER['REDIRECT_HTTP_AUTHORIZATION']
  • token 存数据库或 Redis 查,别用 $_SESSION 存——跨请求失效,且无法水平扩展
  • 别把 token 直接存进 $_COOKIE,Header 更标准、更难被 XSS 泄露

真正麻烦的是错误处理粒度:401(未认证)、403(已认证但无权限)、422(参数错)这些状态码得按场景分清楚,光靠 500 堆日志解决不了问题。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

248

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

522

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

610

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

245

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

739

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3619

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

57

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

74

2026.01.13

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号