PHP 5.6:headers_sent间歇性地返回true,空文件名和第0行
我在我的
PHP脚本(
PHP 5.6,Apache 2.2)中间歇性地遇到了这个问题:
这个警告没有我在其他问题中看过的“发送者”部分,所以我在违规的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等 答案提到了这一点
所以,我现在正在查看我的扩展… 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,mysqlnd,PDO,Phar,posix,shmop,SimpleXML,snmp,soap,sockets,sqlite3,sysvmsg,sysvsem,sysvshm,tokenizer,xml,xmlwriter,xsl,mysql,mysqli,pdo_mysql,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弃用通知,修复了对此处描述的问题没有影响的通知.
我已经看到由于过去的行结束格式而出现问题.您是否将文件从一个操作系统环境移动到另一个?
有时隐藏的回车符(/ r)或其他特殊的空白字符可能会导致这种情况,但在文件中不可见. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |