ignore_user_abort

(PHP 3 >= 3.0.7, PHP 4, PHP 5)

ignore_user_abort --  Set whether a client disconnect should abort script execution

Description

int ignore_user_abort ( [bool setting] )

This function sets whether a client disconnect should cause a script to be aborted. It will return the previous setting and can be called without an argument to not change the current setting and only return the current setting. See the Connection Handling section in the Features chapter for a complete description of connection handling in PHP.

See also connection_aborted(), and connection_status().


add a note add a note User Contributed Notes
spiritual-coder at spiritual-coder dot com
14-Jul-2006 12:45
If you want to simulate a crontask you must call this script once and it will keep running forever (during server uptime) in the background while "doing something" every specified seconds (= $interval):

<?php
ignore_user_abort
(); // run script in background
set_time_limit(0); // run script forever
$interval=60*15; // do every 15 minutes...
do{
  
// add the script that has to be ran every 15 minutes here
   // ...
  
sleep($interval); // wait 15 minutes
}while(true);
?>
15-Dec-2005 04:44
"It will return the previous setting" -- not quite. It returns an int, not a bool (as per the syntax description)
Rustam
27-Jun-2005 07:57
I wrote a simple function that can "spawn" another thread within the webserver by making async http request. The page that is being spawned can call ignore_user_abort() and do whatever it wants in the background...

<?php

  
function http_spawn($page)
   {
      
$basepath=ereg_replace('[^/]*$', '', $_SERVER['PHP_SELF']);
      
$cbSock=fsockopen('localhost', $_SERVER['SERVER_PORT'], $errno, $errstr, 5);
       if (
$cbSock)
       {
          
fwrite($cbSock, "GET {$basepath}{$page} HTTP/1.0\r\n"
              
."Host: {$_SERVER['HTTP_HOST']}\r\n\r\n");
       }
   }
?>

Example:
<?php

  
if ($search_initialized)
      
http_spawn("ftindex.php");
?>
qartis at qartis dot com
06-Sep-2004 07:22
Note that the function name and description seem to be contradictory:

- ignore_user_abort  (TRUE, I want to ignore the user's abort request)
- Set whether a client disconnect should abort script execution (TRUE, I want to set this behavior)

The function name is the authoritative one: a value of TRUE will ignore the user's abort.
plamen at pulsator dot com
30-Mar-2001 01:21
The script should output something to the browser in order to abort. If there is no output the script keeps on running.