jquery ajax ignores 500 status error

前端 未结 3 2013
情歌与酒
情歌与酒 2020-12-10 13:02

I\'m making some GET requests to an App Engine app, testing in Chrome. Whilst I can see in javascript console that some calls result in a 500 server error, I can\'t seem to

相关标签:
3条回答
  • 2020-12-10 13:16

    Solved the problem by upgrading jQuery from 1.9.1 to 2.1.1 — now it started calling .error() right on the server response (before it would ignore the 500 response and wait until timeout is over).

    Limitation: jQuery 2.1.1 does not support IE8 and below (as IMO shouldn't you)

    0 讨论(0)
  • 2020-12-10 13:16

    I had a similar problem, I was using jquery's promise functions of .done, .fail, .always, and if I encountered a 500 internal server error then it would not fire any of the functions (done, fail, always, error). very weird.

    in the end I added a timeout into the .ajax options, when it hits the timeout it throws an error and also runs the .fail method.

    searchify.myAjaxSearchTerms = $.ajax({
                            'url': url,
                            type: "GET",
                            'dataType': 'jsonp',
                            'jsonp': 'json.wrf',
                            'jsonpCallback': searchify.cbFunc,
                            timeout: 4000, //needed for 500 errors - will go to fail block on timeout
                            beforeSend: searchify.beforeSendAutocomplete
    
                        });
    searchify.myAjaxSearchTerms.fail(function(XHR, status, error){
                            searchify.clearForm();
                            searchify.renderWarningForNoQuery('<div class="notify-bubble"><span class="icon" data-icon="8" aria-hidden="true"></span><span>Sorry. We had a problem performing that search...<br/>Please try again<br/>Enter a <strong>product name</strong>, <strong>catalogue number</strong> or <strong>keyword</strong></span></div>');
                        });
    
    0 讨论(0)
  • 2020-12-10 13:35

    It doesn't look like you're using jQuery's document.ready binding correctly. The $().ready(...) version is more-or-less deprecated. Try one of these instead:

    $(document).ready(function() {
        $.ajaxSetup({
            error: function(x, e) {
                if (x.status == 500) {
                    alert('Internel Server Error.');
                }
            }
        });
    });
    

    or the shorthand:

    $(function() {
        $.ajaxSetup({
            error: function(x, e) {
                if (x.status == 500) {
                    alert('Internel Server Error.');
                }
            }
        });
    });
    
    0 讨论(0)
提交回复
热议问题