2012-10-18 9 views
6

Mam następującą funkcję click() jQuery, która musi wysłać dane formularza przez ajax do bazy danych.Czy istnieje maksymalna długość danych dla żądania ajax jQuery

$("#maandbutton").live('click', function(event) { 
    $.get("ajax.php",{"action":"addm","maandtekst":$('#maandtekstinput').val(),"maand":$('#maandselect').val(),"bovenonder":$('#bovenonder').val()},function(msg){ 
     $("#maandtable").append($('<tr><td class="left">' + $('#maandtekstinput').val() + '</td><td class="right">' + $('#bovenonder').val() + '</td><td class="right">' + $('#maandselect').val() + '</td><td class="icon"></td></tr>')); 
     $('table.zebra tr').removeClass('odd'); 
     $('table.zebra tr:odd').addClass('odd'); 
     $('#maandtekstinput').val(''); 
     $('#maandselect').val(''); 
     $('#bovenonder').val(''); 
     $("#maandbutton").button({ disabled: true }); 
    }) 
}); 

Problem polega na tym, że jeśli #maandtekstinput textarea ma za dużo tekstu w nim jedynie Dołącz działa, ale dane nie osiągnie mojej bazy danych SQL.

Mój skrypt ajax.php ma prostą instrukcję zmiany.

$maandtekst = htmlspecialchars($_GET['maandtekst']); 

switch($_GET['action']) 
{ 
    case 'addm': 
     $query = "INSERT INTO `site_maandteksten` (`id`, `maand`, `bovenonder`, `tekst`) VALUES (NULL, '".$maand."', '".$bovenonder."', '".htmlspecialchars_decode($maandtekst)."')"; 
     $result = mysql_query($query) or die(mysql_error()); 
     break; 
} 

Zastanawiam się, dlaczego mój skrypt nie dostarcza mojego tekstu textarea do bazy danych. W mojej bazie danych jest to długie pole tekstowe z przestrzenią 5000 znaków

Odpowiedz

3

Nie używaj kwerendy GET dla dużych danych: użyj testu POST.

$.post("ajax.php",{"action":"addm","maandtekst":$('#maandtekstinput').val(),"maand":$('#maandselect').val(),"bovenonder":$('#bovenonder').val()},function(msg){ 

(aw PHP używać $_POST lub $_REQUEST)

Problem z zapytaniami get to, że parametry są osadzone w adresie URL, który ma ograniczony rozmiar (ograniczenie to jest przeglądarka i serwer zależny).

+1

Ahaaa. Zajęło mi to godzinę debugowania. Dzięki za pomoc to działa :) – user1755868

+0

Zobacz także [Jaka jest maksymalna długość adresu URL?] (Http://stackoverflow.com/q/417142/1338846). –

Powiązane problemy