0

0

PHP创建文件如何添加BOM头_BOM的作用与移除方法【详解】

雪夜

雪夜

发布时间:2026-02-10 12:17:31

|

193人浏览过

|

来源于php中文网

原创

PHP写文件需手动添加BOM头(\xEF\xBB\xBF),因其不提供自动开关;加BOM易致“headers already sent”错误,因BOM被当作输出内容;安全移除须字节级操作,如sed或substr判断截取,mb_convert_encoding无法处理BOM。

php创建文件如何添加bom头_bom的作用与移除方法【详解】

PHP写文件时怎么主动加BOM头

PHP本身不提供“自动加BOM”的开关,fopen()file_put_contents() 等函数默认都写纯UTF-8字节流,不会塞BOM。想加,就得手动拼进去。

常见错误是直接在字符串开头加 "\xEF\xBB\xBF",但要注意:如果内容本身是动态生成的(比如从数据库读取、JSON编码结果),得确保它确实是UTF-8编码,否则BOM+乱码会更难排查。

  • file_put_contents() 时,在内容前显式拼接:file_put_contents($path, "\xEF\xBB\xBF" . $content);
  • fopen() + fwrite() 时,先 fwrite($fp, "\xEF\xBB\xBF");,再写正文
  • 如果内容来自 json_encode(),注意它默认输出 UTF-8,可直接拼;但若用了 JSON_UNESCAPED_UNICODE,仍不影响BOM位置
  • Windows记事本、Excel等老工具依赖BOM识别UTF-8,但现代编辑器(VS Code、PhpStorm)和Web服务器基本不需要——加了反而可能引发HTTP头发送异常

为什么加了BOM会导致header already sent错误

BOM本质是三个不可见字节(\xEF\xBB\xBF),一旦出现在PHP脚本的输出流最前面,就会被当作响应体的一部分发出。而PHP在第一次输出(哪怕只是空格或换行)后,就无法再调用 header()session_start()

典型现象:页面空白,浏览器控制台看到“Failed to load resource”,PHP错误日志里没报错,但 headers_sent() 返回 true

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

  • 检查所有被 includerequire 的PHP文件,尤其是配置文件、函数库——它们如果用UTF-8+BOM保存,就会悄悄触发输出
  • IDE默认保存格式容易设成“UTF-8 with BOM”,比如老版Notepad++、某些Sublime Text配置
  • php -l filename.php 不会报BOM问题,必须用十六进制查看器或 xxd filename.php | head 确认开头三字节

PHP如何安全移除已有文件的BOM头

不能靠简单 trim(),因为BOM只在文件开头,且可能跨多文件批量存在。关键是定位+精准切除。

Product Hunt
Product Hunt

Product Hunt每天都在寻找最好的新产品。

下载

推荐用脚本批量处理,而不是手动改——尤其当项目含几十个.inc/.php文件时。

  • 单文件检测+清理:sed -i '1s/^\xEF\xBB\xBF//' filename.php(Linux/macOS)
  • 递归清理当前目录下所有PHP文件:find . -name "*.php" -exec sed -i '1s/^\xEF\xBB\xBF//' {} \;
  • PHP脚本方式:用 file_get_contents() 读取,判断前3字节是否为 "\xEF\xBB\xBF",是则截掉再写回
  • 注意:Windows下 sed 行为不一致,建议用Git Bash或WSL执行;PowerShell需用 -Encoding Byte 才能准确操作字节

用mb_convert_encoding()处理BOM容易踩的坑

有人试过用 mb_convert_encoding($str, 'UTF-8', 'UTF-8') 想“标准化”编码,结果发现BOM还在——因为这个函数不碰BOM,它只转字符编码逻辑。

更危险的是:如果源字符串已含BOM,又用 mb_convert_encoding() 转成其他编码(如GBK),BOM会被当成普通字符残留,导致输出完全乱套。

  • mb_convert_encoding() 对BOM无感知,既不添加也不删除
  • 真正需要清理BOM时,必须用字节级操作:substr($str, 0, 3) === "\xEF\xBB\xBF" 判断,再 substr($str, 3) 截取
  • 如果后续要写入文件,且不确定目标环境是否需要BOM,宁可不加——绝大多数现代PHP运行环境(Nginx+PHP-FPM、Docker镜像)都默认按UTF-8解析,无需BOM

真正麻烦的不是加或删BOM,而是团队协作中有人用带BOM的编辑器保存,有人用无BOM的,Git diff看不出区别,线上却突然 header 报错。这类问题往往卡在开发机和测试环境的编辑器设置差异上。

相关文章

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

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

下载

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
nginx 重启
nginx 重启

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

235

2023.07.27

nginx 配置详解
nginx 配置详解

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

512

2023.08.04

nginx配置详解
nginx配置详解

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

543

2023.08.04

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

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

237

2024.02.23

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

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

432

2024.07.09

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

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

3585

2024.08.07

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

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

44

2026.01.13

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

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

60

2026.01.13

包子漫画网页版入口与全集阅读指南_正版免费漫画快速访问方法
包子漫画网页版入口与全集阅读指南_正版免费漫画快速访问方法

本专题汇总了包子漫画官网和网页版入口,提供最新章节抢先看方法、正版免费阅读指南,以及稳定访问方式,帮助用户快速直达包子漫画页面,无广告畅享全集漫画内容。

0

2026.02.10

热门下载

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

精品课程

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

共137课时 | 11.3万人学习

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

共6课时 | 11.2万人学习

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

共13课时 | 0.9万人学习

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

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