" 400错误请求"为什么?

时间:2017-10-09 00:46:39

标签: php apache http-post

此函数是使用wxWidgets的PHP-CLI脚本的一部分,该脚本尝试将某些字段发布到LAN上的Apache2 Web服务器。 它总是失败" 400 Bad Request"并且没有输入" /blog/update.php"码。 域/主机的值(可能是此错误的关键部分)是正确的。 为什么这是一个糟糕的要求? 所有与我一样的问题都没有答案。

<?php

[...]

function upload_button_clicked()
{   global $file_box, $frame, $html_box, $remote_host, $title_box, $upload_button ;
    // collect global variables
    $upload_button->Disable();
    $file = $file_box->GetValue();
    $title = $title_box->GetValue();
    $html = $html_box->GetValue();

    // open stream to server
    $messages = "";
    $server = fsockopen($remote_host, 80, $errno, $errstring, 5); 
    if(!$server) 
    {   $messages .= "Cannot connect to $remote_host: $errno $errstring\n"; 
        goto end;
    }
    $messages .= "Connected to $remote_host\n"; 
    stream_set_timeout($server, 5);

    // urlencode parameters
    $body   =   "date=" . urlencode(date('d m Y')) 
                ."&file=" . urlencode($file) 
                ."&title=" . urlencode($title) 
                ."&html=" .  urlencode($html) ;
    $body_length = strlen($body) +1;  for the "\n" to terminate

    // build POST request
    $request =  "POST /blog/update.php HTTP/1.1\n"
                ."Host: $remote_host\n"
                ."Content-Type: application/x-www-form-urlencoded\n"
                ."Content-Length: $body_length\n"
                ."\n"
                .$body."\n";


    // fwrite request to stream
    loop:
    $request_length = strlen($request);
    $bytes_written = fwrite($server, $request, $request_length);
    if($bytes_written === false)
    {   $messages .= "Writing POST to $remote_host failed";
        goto end ;
    }

    // deal with partial write
    if($bytes_written < $request_length)    // not all written
    {   $request = substr($request, $bytes_written);
        goto loop;
    }
    $messages .= "sent $file OK\n";

    // read responses to POST
    while(!feof($server))
    {   $response = fgets($server, 1024);
        $messages .= "$response\n";
    }

    // tidy up
    end:
    $report = new wxMessageDialog($frame, $messages, "Upload", wxOK|wxCENTRE);
    fclose($server);
    $upload_button->Enable();
    return ;
}

[...]

?>

终端输出:

Connected to mydomain.com
sent /home/.../blog/contents/201710090746+title.htm OK
HTTP/1.1 400 Bad Request

Date: Sun, 08 Oct 2017 21:46:08 GMT

 Server: Apache

Content-Length: 285

Connection: close

Content-Type: text/html; charset=iso-8859-1

<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">

<html><head>

<title>400 Bad Request</title>

</head><body>

<h1>Bad Request</h1>

<p>Your browser sent a request that this server could not understand.<br />

</p>

<hr>

<address>Apache Server at 127.0.0.1 Port 80</address>

</body></html>

2 个答案:

答案 0 :(得分:0)

尝试

$body_length = strlen($body."\n");

您发送给Apache的正文略长于strlen($body),因为您要将"\n"追加到$body的末尾。由于此原因,至少one other coder收到400 Bad Request。

答案 1 :(得分:0)

尝试使用\r\n代替\n,如下所示:

$body_length = strlen($body);

// build POST request
$request =  "POST /blog/update.php HTTP/1.1\r\n"
            ."Host: $remote_host\r\n"
            ."Content-Type: application/x-www-form-urlencoded\r\n"
            ."Content-Length: $body_length\r\n"
            ."\r\n"
            .$body;