php设置返回文件名,PHP 5.6:headers_sent间歇性地返回true,空文件名和第0行

我在我的

PHP脚本(

PHP 5.6,Apache 2.2)中间歇性地遇到了这个问题:

Warning: Cannot modify header information – headers already sent in /path/to/index.PHP on line 55

这个警告没有我在其他问题中看过的“发送者”部分,所以我在违规的header()和setcookie()调用之前添加了这段代码:

if (headers_sent($filename,$linenum)){

echo("Output buffer: #" . ob_get_contents() . "#");

echo "Headers already sent in $filename on line $linenum: ";

print_r(headers_list());

}

这是问题发生时我得到的输出:

Output buffer: ##

Headers already sent in on line 0:

Array (

[0] => X-Powered-By: PHP/5.6.23

[1] => Content-type: text/html; charset=UTF-8

)

(旁注:我在PHP.ini中将output_buffering设置为4096字节,所以不应该缓冲这两个标题中的63个字符并等待更多,而不是过早发送?)

第一次启动包含Web服务器的Docker容器时出现此问题.之后,当我第一次访问我的网站一段时间(可能是一两个小时),当我调用header()和setcookie()来记录用户或重定向到登录页面.

我已经阅读并重读了this answer到一般的“Headers already sent”错误,并且尽我所能,我已经排除了这些可能的原因:

>在我调用setcookie()或header()之前,HTML阻止或调用print,echo等

>我的PHP标签之外的空格

> BOM

> auto_prepend_file PHP.ini设置

> gzip stream encoding – 已安装zlib,但zlib.output_compression已关闭

>重复扩展= p​​hp.ini设置

答案提到了这一点

It’s typically a PHP extension or PHP.ini setting if no error source is concretized.

所以,我现在正在查看我的扩展… get_loaded_extensions为我提供了一个包含这些条目的51长度数组:

Core,date,ereg,libxml,openssl,pcre,zlib,filter,hash,Reflection,SPL,session,standard,apache2handler,bz2,calendar,ctype,curl,dom,exif,fileinfo,ftp,gd,gettext,iconv,@R_403_198@nd,PDO,Phar,posix,shmop,SimpleXML,snmp,soap,sockets,sqlite3,sysvmsg,sysvsem,sysvshm,tokenizer,xml,xmlwriter,xsl,@R_403_198@,@R_403_198@i,pdo_@R_403_198@,pdo_sqlite,wddx,xmlreader,json,zip,mhash

我没有使用所有这些,所以我打算通过并删除未使用的,并希望其中一个导致问题.

最糟糕的情况,我会尝试碰撞我的output_buffering值或使用ob_start()和ob_end_flush()来查看我的文件的开头和结尾.我不知道为什么当我当前的output_buffering值为4096时,这会解决它,我明白这个解决方法有自己的问题.

我在这里缺少什么 – 我还需要检查其他可能的原因吗?我应该尝试不同的PHP版本,还是在没有扩展的干净PHP安装上运行我的代码子集?

编辑:添加了ob_get_contents()调用和输出,以及有关能够通过旋转新的Docker容器一致地重现这一点的信息.删除了有关我的error_reporting值的信息;更改此项仅发现了always_populate_raw_post_data弃用通知,修复了对此处描述的问题没有影响的通知.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值