I’m making a AJAX request like this:
$("#botao_pesquisar_material").click(function(){
$(this).attr("disabled", "disabled");
$("#material").addClass('loading');
$.ajax({
url: '{{ URL::base() }}/material/lista_ajax/',
dataType: 'json',
cache: false,
error: function(data)
{
console.log(data);
},
success: function(data) {
for(x in data)
{
console.log(data[x]);
}
}
});
My PHP method is ok because when I access it via URL, it returns me the expected JSON and when I call this on localhost, it works perfectly so it isn’t about special characters or something else with the data.
When I run this on my server I have this:
GET http://dc.portaldeideias.com.br:8080/sergios/public/material/lista_ajax/?callback=jQuery172007718208665028214_1342725644520&_=1342725649090 500 (Internal Server Error) jquery.js:4
f.support.ajax.f.ajaxTransport.send jquery.js:4
f.extend.ajax jquery.js:4
$.click.$.ajax.url
f.event.dispatch jquery.js:3
f.event.add.h.handle.i
Using console.log(data) I have the entire JSON response but here is what is really strange:
The readyState is 4
The responseText is [{"attributes":{"pk_a030_id":78,"a030_descricao":"Camur\u00e7a"},"original":{"pk_a030_id":78,"a030_descricao":"Camur\u00e7a"},"relationships":[],"exists":true,"includes":[]}]
The statusText is Internal Server Error
So, the requested value is created but I receive a Internal Server Error
Sorry for posting this as an answer, but I don’t have the required privileges to add this as a comment for your question.
Have you noticed that the URL in the javascript log
http://localhost:8080/sergios/public/material/lista_ajax/is different than the one provided in your screenshothttp://dc.p[...]s.com.br:8080/sergios/public/material/lista_ajax?Could it be the case that you have two different versions of the
lista_ajaxPHP method hosted in two different servers (maybe one remote and the other one local), and that’s why it works flawless when seeing it from the browser and has bugs when tested with ajax?It’s also important to notice that if you are browsing a website hosted on a remote server, and the ajax is configured to a
localhostaddress, it will do a request for your own machine, not the remote server (javascript runs in the browser, solocalhosttranslates to its own client address).Maybe this is not the case, but it was worth commenting.