React to 303 status code in jquery ( Prevent from redirecting)
Asked Answered
S

5

14

when I send requests to a certain server, a 303 response will come, followed by the requested response in combination with a 200 status code. Funny thing is that I only see this on my developer console's network view. When checking the statuscode and response of my $.ajax() request, there will be the response of the second request, as well as a 200 http status code.

The problem is that it seems that the second request is being cached (though 200 status code), and I really need it to be non-cachable. Therefore I'd really like to intervene into the forwarding process that occurs with a http 303 status code. I'd like my jquery function to check for the status code, then send the get request with explicit headers, that tell the server not to cache the response.

Well, I just don't know how to do this, since (as mentioned above) the jQuery.ajax method will respond with the forwarded request's response and status code (200).

Can you help me?

edit

10.3.4 303 See Other

The response to the request can be found under a different URI and SHOULD be retrieved using a GET method on that resource. This method exists primarily to allow the output of a POST-activated script to redirect the user agent to a selected resource. The new URI is not a substitute reference for the originally requested resource. The 303 response MUST NOT be cached, but the response to the second (redirected) request might be cacheable.

maybe I need to somehow prevent the user agent from redirecting himself, so I can do the redirect?

Or is there a way to simply tell the server/browser not to cache the second request from client-side? or to prevent it from redirecting my request? or at least modify the second request before redirecting?

Sabellian answered 2/5, 2013 at 12:9 Comment(1)
I have no access to the server except http requestsSabellian
J
9

Responses in the 300 range are meant to be transparent. AFAIK, web browsers don't expose any of them to javascript. Thus, handling the 303 is not an option.

Have you tried setting the cache property to false in the ajaxSetup? It will append a timestamp to the request, preventing the browser from caching the response. You can also do that manually yourself. The browser should match the first request url to the 2nd response

Jerrome answered 21/5, 2013 at 0:26 Comment(1)
This helped me understand why IE does not return response body to JS for a 303 (although Chrome does). Thanks!Ephor
V
2

You cannot stop the browser from following the 303 redirect. It sounds like that's not what you want, anyway. Whatever you would do in the browser to prevent the original request from being cached should work equally well for preventing the redirected 200 from being cached. That said, there is little you can do on the browser side other than using a unique URL for each request. This is done for you automatically by jQuery when you set cache: false.

$.ajax({
  url: "example.html",
  cache: false
  }
}).done(function( html ) {
  $("#results").append(html);
});
Videlicet answered 1/6, 2013 at 18:5 Comment(0)
P
1

This is old post, but maybe someone will find this useful.

I have the same issue, and in my case the problem was in the method that was called out using the ajax. The problem was in the redirection that was set in the method. So, based on this, you can't use both ajax and redirect(server side), and i removed redirect() function from method, i everything works as expected. Btw, i am using codeigniter.

Phane answered 20/11, 2015 at 19:37 Comment(0)
U
0
 $(".radio-input").click(function(e) {
            var visible_div_id = $(VISIBLE_ELEMENT).attr('data-id');
            var sectionid = $(VISIBLE_ELEMENT + " .section-id").val();
            var time_spend = $(VISIBLE_ELEMENT + " .time-spent").val();
            var report_time = $("#remaning-time").val();
            var answer = $(this).val();

            console.log(visible_div_id, sectionid, time_spend, report_time, answer);

            $.ajax({
                url: "<?= base_url('Quiz/save') ?>",
                type: 'POST',
                data: {
                    stu_id: '<?= $this->studentData['id'] ?>',
                    quesid: visible_div_id,
                    sectionid: sectionid,
                    useroption: answer,
                    time_spent: time_spend,
                    report_time: report_time,
                    testid: '<?= $details['id'] ?>',
                },
                success: function(data) {
                    console.log('Answer saved successfully:', data);
                    for (var k in dict2) {
                        $.ajax({
                            url: "<?= base_url('Quiz/save') ?>",
                            cache: false,
                            type: 'POST',
                            data: dict2[k],
                            success: function(data) {
                                console.log("Pending answers saved successfully:", data);
                            },
                        });
                    }
                    dict2 = {};
                },
                error: function(jqXHR) {
                    console.log("Error saving answer, saving locally:", jqXHR);
                    console.log("Response Text:", jqXHR.responseText); // Add this line
                    dict2[visible_div_id] = {
                        stu_id: '<?= $this->studentData['id'] ?>',
                        quesid: visible_div_id,
                        sectionid: sectionid,
                        useroption: answer,
                        time_spent: time_spend,
                        report_time: report_time,
                        testid: '<?= $details['id'] ?>'
                    };
                    console.log(dict2);
                }
            });
        }); same issue 303 how to solve it
Unequal answered 5/6, 2024 at 7:22 Comment(1)
As it’s currently written, your answer is unclear. Please edit to add additional details that will help others understand how this addresses the question asked. You can find more information on how to write good answers in the help center.Agrology
W
-1

See statusCode property of your .ajax() call

Example :

$.ajax({
  statusCode: {
    303: function() {
      alert("page not found");
    }
  }
});
Whet answered 2/5, 2013 at 12:13 Comment(2)
as I said: "When checking the statuscode and response of my $.ajax() request, there will be the response of the second request, as well as a 200 http status code." .. the same goes for this approach. I tried it with $.ajax({ statusCode: { 303: function() { alert(303); },200: function() { alert(200); } } }); it always jumps into the 200 method.Sabellian
Is there any solution how to get the data of the 303 response?Agamogenesis

© 2022 - 2025 — McMap. All rights reserved.