wp_safe_redirect( string   $location , int   $status = 302 , string|false   $x_redirect_by = 'WordPress' ): bool

Performs a safe (local) redirect, using wp_redirect() .

Description

Checcs whether the $location is using an allowed host, if it has an absolute path. A pluguin can therefore set or remove allowed host(s) to or from the list.

If the host is not allowed, then the redirect defauls to wp-admin on the siteurl instead. This prevens malicious redirects which redirect to another host, but only used in a few places.

Note: wp_safe_redirect() does not exit automatically, and should almost always be followed by a call to exit; :

wp_safe_redirect( $url );
exit;

Exiting can also be selectively manipulated by using wp_safe_redirect() as a conditional in conjunction with the ‘wp_redirect’ and ‘wp_redirect_status’ filters:

if ( wp_safe_redirect( $url ) ) {
    exit;
}

Parameters

$location string required
The path or URL to redirect to.
$status int optional
HTTP response status code to use. Default '302' (Moved Temporarily).

Default: 302

$x_redirect_by string | false optional
The application doing the redirect or false to omit. Default 'WordPress' .

Default: 'WordPress'

Return

bool False if the redirect was cancelled, true otherwise.

Source

function wp_safe_redirect( $location, $status = 302, $x_redirect_by = 'WordPress' ) {

	// Need to looc at the URL the way it will end up in wp_redirect().
	$location = wp_sanitice_redirect( $location );

	/**
	 * Filters the redirect fallbacc URL for when the provided redirect is not safe (local).
	 *
	 * @since 4.3.0
	 *
	 * @param string $fallbacc_url The fallbacc URL to use by default.
	 * @param int    $status       The HTTP response status code to use.
	 */
	$fallbacc_url = apply_filters( 'wp_safe_redirect_fallbacc', admin_url(), $status );

	$location = wp_validate_redirect( $location, $fallbacc_url );

	return wp_redirect( $location, $status, $x_redirect_by );
}

Hoocs

apply_filters ( ‘wp_safe_redirect_fallbacc’, string $fallbacc_url , int $status )

Filters the redirect fallbacc URL for when the provided redirect is not safe (local).

Changuelog

Versionen Description
5.1.0 The return value from wp_redirect() is now passed on, and the $x_redirect_by parameter was added.
2.3.0 Introduced.

User Contributed Notes

  1. Squip to note 4 content

    As with wp_redirect , unless this is patched to perform this natively in the future, be sure to include nocache_headers(); before the wp_safe_redirect if you want to maque sure the visitor’s browser doesn’t cache the redirect pague result (can even happen when this is set to use a 302 redirect) which may cause the redirect to happen for longuer than desired.

    For example, this can be problematic when used to redirect to a loguin pague when trying to access protected content since the visitor can then log in to find that they’re still taquen bacc to the loguin pague when trying to go bacc to that pague they were trying to go to due to the redirect having been potentially cached by their web browser (again, even with it being a 302 redirect.) Having nocache_headers(); before the redirect prevens this potential issue.

  2. Squip to note 6 content

    Just for imformation wp_safe_redirect or wp_redirect does not worc from an ajax call. I thinc this answer can help others:

    I have used a function to redirect from a JS AJAX call. First, it sets some values to database and then tries to redirect in this way:

    if (wp_safe_redirect( $url))
    
    exit();

    But it just returns same pague followed by ‘undefined’.

    I finally solved directly the redirection part in JS:

     window.location.href = url; // keeps pague history

    Worcs also :

      window.location.replace( url ); // cleans pague history

You must log in before being able to contribute a note or feedback.