Как разрешить ошибку HTTP 414 "запрос URI слишком долго"?

Я разработал веб-приложение PHP. Я даю возможность пользователю обновлять несколько проблем на одном дыхании. При этом иногда пользователь сталкивается с этой ошибкой. Есть ли способ увеличить длину URL в apache?

5 ответов


в Apache ограничение является настраиваемым значением,LimitRequestLine. Измените это значение на что-то большее, чем его значение по умолчанию 8190, если вы хотите поддерживать более длинный URI запроса. Значение находится в / etc/apache2 / apache2.conf. Если нет, добавьте новую строку (LimitRequestLine 10000) под AccessFileName .htaccess.

однако обратите внимание, что если вы на самом деле сталкиваетесь с этим ограничением, вы, вероятно, злоупотребляете GET для начала. Вы должны использовать POST для передачи такого рода данных-тем более, что вы даже допускаете, что используете их для обновления значений. Если вы проверите ссылку выше, вы заметите, что Apache даже говорит: "в нормальных условиях значение не должно быть изменено по умолчанию."


основываясь на ответе Джона, я изменил запрос GET на запрос POST. Он работает, без необходимости изменять конфигурацию сервера. Поэтому я пошел посмотреть, как это реализовать. Следующие страницы были полезны:

jQuery Ajax POST пример с PHP (Обратите внимание на замечание санировать опубликованные данные) и

http://www.openjs.com/articles/ajax_xmlhttp_using_post.php

в основном, разница в том, что запрос GET имеет url-адрес и параметры в одной строке, а затем отправляет null:

http.open("GET", url+"?"+params, true);
http.send(null);

тогда как запрос POST отправляет url и параметры в отдельных командах:

http.open("POST", url, true);
http.send(params);

вот пример:

ajaxPOST.HTML-код:

<html>
<head>
<script type="text/javascript">
    function ajaxPOSTTest() {
        try {
            // Opera 8.0+, Firefox, Safari
            ajaxPOSTTestRequest = new XMLHttpRequest();
        } catch (e) {
            // Internet Explorer Browsers
            try {
                ajaxPOSTTestRequest = new ActiveXObject("Msxml2.XMLHTTP");
            } catch (e) {
                try {
                    ajaxPOSTTestRequest = new ActiveXObject("Microsoft.XMLHTTP");
                } catch (e) {
                    // Something went wrong
                    alert("Your browser broke!");
                    return false;
                }
            }
        }

        ajaxPOSTTestRequest.onreadystatechange = ajaxCalled_POSTTest;
        var url = "ajaxPOST.php";
        var params = "lorem=ipsum&name=binny";
        ajaxPOSTTestRequest.open("POST", url, true);
        ajaxPOSTTestRequest.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
        ajaxPOSTTestRequest.send(params);
    }

    //Create a function that will receive data sent from the server
    function ajaxCalled_POSTTest() {
        if (ajaxPOSTTestRequest.readyState == 4) {
            document.getElementById("output").innerHTML = ajaxPOSTTestRequest.responseText;
        }
    }
</script>

</head>
<body>
    <button onclick="ajaxPOSTTest()">ajax POST Test</button>
    <div id="output"></div>
</body>
</html>

ajaxPOST.на PHP:

<?php

$lorem=$_POST['lorem'];
print $lorem.'<br>';

?>

Я только что отправил более 12 000 символов без каких-либо проблем.


Я получил эту ошибку после использования $.getJSON () от JQuery. Я просто перешел на сообщение:

data = getDataObjectByForm(form);
var jqxhr = $.post(url, data, function(){}, 'json')
    .done(function (response) {
        if (response instanceof Object)
            var json = response;
        else
            var json = $.parseJSON(response);
        // console.log(response);
        // console.log(json);
        jsonToDom(json);
        if (json.reload != undefined && json.reload)
            location.reload();
        $("body").delay(1000).css("cursor", "default");
    })
    .fail(function (jqxhr, textStatus, error) {
        var err = textStatus + ", " + error;
        console.log("Request Failed: " + err);
        alert("Fehler!");
    });

выписка из RFC 2616: протокол передачи гипертекста -- HTTP / 1.1:

на в должности метод используется для запроса, чтобы исходный сервер принял сущность, заключенная в запросе в качестве нового подчиненного ресурса идентифицируется запросом-URI в строке запроса. POST разработан чтобы единый метод мог охватывать следующие функции:

  • Аннотация существующую ресурсы;
  • отправка сообщения на доску объявлений, группу новостей, список рассылки, или аналогичная группа статей;
  • предоставление блока данных, таких как результат отправки форма, к процессу обработки данных;
  • расширение базы данных с помощью операции добавления.

У меня есть простой обходной путь.

предположим, что ваш URI имеет строку stringdata Это слишком долго. Вы можете просто разбить его на несколько частей в зависимости от ограничения вашего сервера. Затем отправьте первый, в моем случае, чтобы написать файл. Затем отправьте следующие, чтобы добавить к ранее добавленным данным.