To nie zadziałało z żadną z twoich odpowiedzi, ale tylko dodając małą rzecz, zadziałało! Oto mój kod:
function login_redirect( $redirect_to, $request, $user ){
if(isset($_REQUEST['redirect_to'])){
return $_REQUEST['redirect_to'];
}
return admin_url();
}
add_filter( 'login_redirect', 'login_redirect', 10, 3 );
function restrict_access_if_logged_out(){
if (!is_user_logged_in() && !is_home()){
$redirect = home_url() . '/wp-login.php?redirect_to=' . esc_url($_SERVER["HTTP_HOST"] . urlencode($_SERVER["REQUEST_URI"]));
wp_redirect( $redirect );
exit;
}
}
add_action( 'wp', 'restrict_access_if_logged_out', 3 );
Tylko dodałem /wp-login.php
w porównaniu do odpowiedzi @ Matta, ale dla mnie był kluczem. Mam nadzieję, że to pomaga! :)
**EDYTOWAĆ:
Wykryłem BŁĄD, gdy wymuszasz wordpress, aby nawigować w HTTPS. Ta metoda nie działa, ponieważ przekierowanie odbywa się w HTTP. Aby rozwiązać problem, zmieniłem funkcję. Oto wynik:
function restrict_access_if_logged_out(){
global $wp;
$protocol='http';
if (isset($_SERVER['HTTPS']))
if (strtoupper($_SERVER['HTTPS'])=='ON')
$protocol='https';
if (!is_user_logged_in() && !is_home() && ($wp->query_vars['pagename'] != 'downloads') ){
$redirect = home_url() . "/wp-login.php?redirect_to= $protocol://" . $_SERVER["HTTP_HOST"] . urlencode($_SERVER["REQUEST_URI"]);
wp_redirect( $redirect );
exit;
}
}
add_action( 'wp', 'restrict_access_if_logged_out', 3 );
I sprawdzić protokół i potem usunięty „ esc_url
” i dodał prawidłowy protokół: $protocol://
. Również zmieniłem ""
.
Opieram się na tej stronie .