若浏览器显示OK则short_open_tag已生效;若显示空白、500错误或原样输出,则未生效或被Nginx等覆盖;命令行php -f test.php结果不反映Web环境,因CLI与FPM/Apache的php.ini可能不同。

PHP 短标签 为什么默认不生效?
PHP 7.4+ 版本起,short_open_tag 默认为 Off,所以 和 =(除非是纯输出)在大多数新环境里直接报错或原样输出。这不是语法错误,而是配置被禁用了——哪怕代码本身完全合法。
如何开启 short_open_tag(php.ini 修改)
找到你实际生效的 php.ini 文件(运行 php --ini 或 phpinfo() 查看“Loaded Configuration File”),然后修改这一行:
short_open_tag = On
改完必须重启 Web 服务(如 sudo systemctl restart apache2 或 sudo systemctl restart php-fpm && sudo systemctl restart nginx),仅 reload 不生效。
- 如果用的是 Docker,得在构建镜像时 COPY 修改后的
php.ini,或通过php_ini_values覆盖(取决于基础镜像支持) - 共享主机通常禁止修改
php.ini,此时只能用ini_set('short_open_tag', '1')—— 但该函数对short_open_tag无效,别试 -
=在 PHP 5.4+ 是硬编码支持的,不受short_open_tag控制;但(无等号)、以外的变体(如)仍依赖此开关
替代方案:不用短标签更稳妥
开启短标签看似省事,但会带来隐性成本:
立即学习“PHP免费学习笔记(深入)”;
- 和 XML/HTML 混写时,
可能被误解析(即使short_open_tag=On,PHP 也会跳过以开头的行,但行为不统一) - 团队协作或开源项目中,很多 IDE、静态分析工具(如 PHPStan、Psalm)默认不识别
,提示“未定义标签”或语法高亮异常 - PHP 8.4+ 已明确将移除对
(非=)的支持提案进入讨论阶段,兼容性窗口正在收窄
真正需要兼容老代码时,优先用 sed -i 's/\([^=]\|$\)/ 批量替换,比长期维护一个开关更可靠。
验证是否生效的最简方式
建一个 test.php,内容只有一行:
='OK';?>
访问它。如果浏览器显示 OK,说明 short_open_tag 已生效;如果显示空白、500 错误或原样输出 ='OK';?>,说明没生效或被其他层(如 Nginx 的 fastcgi_params)覆盖。
注意:php -f test.php 命令行执行结果不能代表 Web 环境,CLI 和 FPM/Apache 的 php.ini 可能不同。











