I was wondering if there's a simple way to cancel an AJAX request?
Beyond just calling an 'abort' on the XMLHTTPRequest on the client side, is there a way to easily stop the server process? The server is using Apache.
Thanks
I was wondering if there's a simple way to cancel an AJAX request?
Beyond just calling an 'abort' on the XMLHTTPRequest on the client side, is there a way to easily stop the server process? The server is using Apache.
Thanks
No. There's definitely no simple way.
I can think of some complex ways, but they would be unreliable.
You'll probably have more luck developing a process for reversing the changes from a request you've just run (I'm assuming that's the reason you would want to stop it.)
Initiate another Ajax request. I found this thread by trying to figure out how to prevent a previous request from being interrupted when another is called.
there are no good ways to stop the request itself over the network (as many have said), but it's relatively easy to stop the effects of the request. i.e.
on the server-side: you could exit
(or whatever term you'd require to kill the script) by constantly checking global variables (acting as flags) like cookies or sessions (again, assuming these would change during the execution of the script). additionally, you could keep files or database entries as flags (that you can poll for existence).
on the client-side: you could call abort
(which doesn't work in all browsers, like others have said), or you could keep a global semaphore / flag at the top of your callback (that checks the global value to see if it should still execute or not). example:
window.ajaxIsStillGood = true;
xhr.onreadystatechange = function( )
{
if( 4 === xhr.readyState && 200 === xhr.status )
{
if( true === window.ajaxIsStillGood ){ /* still good */ }
}
}
/* bad stuff happens */
window.ajaxIsStillGood = false; // now the code won't execute
The easiest way would be just to send a 503 (or similar) HTTP Response header and abort the server-side application (or just abort the application). Assuming no data was sent and/or you checked the HTTP response header client side you can just treat it as a failed request.
The short answer is "no". Unless you're talking about a very long running backgrounded process on the server side, in which case you could have a second Ajax request initiate a stop on it. But if you're talking about a regular request to an Apache/PHP server, then no... identifying which Apache thread your request was running in would be trouble enough.
It would be much easier to verify your Ajax request somehow before even starting the process; make sure it's what you want to be running. You could have a Javascript confirmation process as well if you need the user to be aware that what they are doing cannot be interrupted.
As Steven posted, having a reversal process sounds like it might be in your best interest as well.
How about sending another Ajax request that would change particular $_SESSION
var which is monitored by that long process?
For PHP I have found a way to stop or abort by using session_write_close();
. Just put this after session_start()
on your script. If you are using framwework or OOP then keep it as first line of your method. This happens because session data is locked until the ajax has finished.
Tested & saw another page is now loading after xhr.abort()
Solution hints found here Abort Ajax requests using jQuery