错误500:脚本标头过早结束

时间:2013-07-11 00:53:41

标签: php cgi

运行以下脚本时出现“脚本标题过早结束:contactform.cgi”错误消息。让我感到沮丧的是,我在另一台服务器上以.php的形式运行它并且它有效。但是,我不得不更换服务器,它们只支持CGI PHP。但是,它不起作用。我不认为代码是错的,但看看以防万一。

我已经读完了,有些人说这是权限问题。这可能是我的情况吗?

我知道“display_errors”和“error_reporting”语句会在错误日志中显示错误,但如果我无法访问服务器,我该如何查看日志?

#!/usr/local/bin/php

<?php

print "Content-type: text/html\n\n";
use CGI::Carp qw(fatalsToBrowser);
ini_set('display_errors',1);
error_reporting(E_ALL);

if(isset($_POST['email'])) {

//Email this form to me
$email_to = "myemail@yahoo.com";

function died($error) {
    // your error code can go here
    echo "Oops... something's wrong. ";
    echo "Fix the error(s) below:<br /><br />";
    echo $error."<br /><br />";
    echo "All your base are belong to us...<br /><br />";
    die();
}


// validation expected data exists
if(!isset($_POST['first_name']) ||
    !isset($_POST['last_name']) ||
    !isset($_POST['email']) ||
    !isset($_POST['subject']) ||
    !isset($_POST['comments'])) {
    died('There appears to be a problem with the form you submitted.');       
}


$first_name = $_POST['first_name']; // required
$last_name = $_POST['last_name']; // required
$email_from = $_POST['email']; // required
$subject = $_POST['subject']; // not required
$comments = $_POST['comments']; // required

$error_message = "";
$email_exp = '/^[A-Za-z0-9._%-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4}$/';
if(!preg_match($email_exp,$email_from)) {
$error_message .= 'The Email Address you entered does not appear to be valid.<br />';
}
$string_exp = "/^[A-Za-z .'-]+$/";
if(!preg_match($string_exp,$first_name)) {
$error_message .= 'The First Name you entered does not appear to be valid.<br />';
}
if(!preg_match($string_exp,$last_name)) {
$error_message .= 'The Last Name you entered does not appear to be valid.<br />';
}
if(strlen($comments) < 2) {
$error_message .= 'The Comments you entered do not appear to be valid.<br />';
}
if(strlen($error_message) > 0) {
died($error_message);
}


$email_message = "Form details below.\n\n";

function clean_string($string) {
  $bad = array("content-type","bcc:","to:","cc:","href");
  return str_replace($bad,"",$string);
}

$email_message .= "First Name: ".clean_string($first_name)."\n";
$email_message .= "Last Name: ".clean_string($last_name)."\n";
$email_message .= "Email: ".clean_string($email_from)."\n";
$email_message .= "Subject: ".clean_string($subject)."\n";
$email_message .= "Comments: ".clean_string($comments)."\n";

//Email Subject (put here to include subject from form)
$email_subject = "COR | ".clean_string($subject)."";


// create email headers
$headers = 'From: '.$email_from."\r\n".
'Reply-To: '.$email_from."\r\n" .
'X-Mailer: PHP/' . phpversion();
@mail($email_to, $email_subject, $email_message, $headers);
?>

<!-- include your own success html here -->

<?php
header("Location: cor/thankyou.html");
}
?>

16 个答案:

答案 0 :(得分:35)

我以为我会回答我自己的问题,因为踢腿和咯咯笑声(以及那些可能有一天会发现自己有同样错误而没有答案的人)。

这是文件许可问题。

我网站上的所有文件都设置为'644'的权限。一旦我将权限级别更改为705(chmod 705 [chmod 755也可以工作])一切都很好,花花公子。这并不重要,但我还将其所在的文件夹更改为701(隐藏它,但仍可由服务器执行)。

我仍然不明白为什么我的.PHP文件可能在其他服务器上运行时可能设置为644? Apache如何在没有世界许可的情况下执行脚本? Apache不需要世界许可吗?我还有几个问题......

答案 1 :(得分:9)

“脚本标头的过早结束”错误消息可能是您将找到的最厌恶和常见的错误消息。 错误的实际含义是,脚本在将任何输出返回到Web服务器之前因任何原因而停止。 脚本编写者的常见原因是在打印输出代码之前无法设置内容类型。例如,在Perl中,在打印任何HTML之前,必须告诉Perl脚本将内容类型设置为text / html,这是通过发送标题来完成的,如下所示:

print "Content-type: text/html\n\n";

(来源; http://htmlfixit.com/cgi-tutes/tutorial_Common_Web_dev_error_messages_and_what_they_mean.php#premature

答案 2 :(得分:2)

它与文件权限有关,它发生在安装了suphp(通常是cpanel / whost服务器)的系统上。

从除了所有者(644 | 600)之外的任何人删除写入权限以获取php文件将解决此问题。这就是我修复它的方法。

我希望这会有所帮助。

答案 3 :(得分:1)

检查你的行尾!如果您看到有关该文件未找到的错误,则会出现这个&#34;结束标头过早的问题&#34; Apache日志中的错误 - 可能是您的脚本中的Windows行结尾而不是Unix样式。我遇到了这个问题/解决方案。

答案 4 :(得分:1)

要解决此问题,我必须将整个目录的权限更改为755(777对我不起作用),并更改整个目录的文件所有者

chmod -R 755 public_html
chown -R nobody:nobody public_html

没有人是在我的电脑上运行php的用户。

答案 5 :(得分:1)

错误可能由各种问题引起。有关更多信息,请检查suexec或fcgi日志。 例如,如果suexec有错误的用户和permssion,它可能导致错误发生 解决尝试

chgrp WEBGROUP /usr/local/apache2/bin/suexec
chmod 4750 /usr/local/apache2/bin/suexec

答案 6 :(得分:1)

我今天遇到了这个问题,但不幸的是,这里没有任何建议有帮助。唯一的问题是我没有看到任何错误..我实际上必须在Apache线程上执行strace -p <process_id>来发现正在编写的头文件并且Apache崩溃在下一行;在我的PHP代码的某个地方,我设置了一个包含12KB以上数据的标题。

这里的教训是,在某些情况下,Apache崩溃时出现HTTP error 500 - Premature end of script - 失败可能是由于HTTP标头太长或溢出造成的。

如果遇到同样的问题,请调试标头的长度,因为大多数(如果不是全部)Web服务器都有HTTP标头限制。

PS:This reply有一些关于标题大小的信息。

答案 7 :(得分:1)

在我的情况下,我不得不改变

#!/usr/bin/php

#!/usr/bin/php-cgi

答案 8 :(得分:1)

在我的情况下,这不是一个很大的缓存目录,只有17MB,但是由于文件结构的双重影响,网站永远需要访问它,并且在达到max_execution_time之后会产生该错误。

我将目录重命名为cache-BK并创建了具有相同权限的新缓存目录,从而解决了该问题。

答案 9 :(得分:0)

你忘了在响应中添加正确的内容类型标头,这是在apache2上托管时必须具有的http标头

使用

print "Content-type:text/html\r\n\r\n"

header('Content-Type: text/html');

答案 10 :(得分:0)

我尝试了以上所有但发现它是一个缺少的Windows编译器。

下载并安装此修复了该问题。要查看这是否是您的问题,请尝试从命令行运行PHP。

msvcr110.dll is missing from computer error while installing PHP

答案 11 :(得分:0)

在我的情况下(引用Wordpress插件顶部文件夹中的PHP文件)我不得不更改该文件夹的权限。我的测试环境很好,但是在部署时,文件夹有775.我将其更改为755并且工作正常。

答案 12 :(得分:0)

我有这个问题并通过将PHP版本从5.3.3更改为5.6.30来解决此问题。

答案 13 :(得分:0)

经过多次讨论之后,这就是有问题的服务器上的httpd.conf文件中缺少的内容:

AddHandler php5-script .php

解决了这个问题。

答案 14 :(得分:0)

在增加Apache的默认LimitRequestFieldSize和LimitRequestLine值之后,我使用PHP-FPM和Apache遇到了这个问题。

我这样做的唯一原因(Apache说不要搞乱)是因为Yii2在POST请求中存在一些pjax问题。作为解决方法,我决定增加这些限制并使用巨大的GET标头。

php-fpm拒绝了500错误。

答案 15 :(得分:0)

该线程最新出现,但是我在页面上间歇性地收到此错误,该页面仅在99%的时间内加载。另外,如果在出现错误后刷新浏览器,则页面会正确加载。鉴于此,我认为这不是权限问题,但我不知道还有什么要解决的,而且我的网络托管服务商也没有帮助。