На основании ответа Джона я изменил запрос GET на запрос POST. Работает без изменения конфигурации сервера. Итак, я посмотрел, как это реализовать. Следующие страницы были полезны:
Пример jQuery Ajax POST с PHP
(Обратите внимание на примечание о проведенной дезинфекции) и
http://www.openjs.com/articles/ajax_xmlhttp_using_post.php
По сути, разница в том, что запрос GET имеет URL-адрес и параметры в одной строке, а затем отправляет ноль:
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 символов без проблем.