Não funcionou nenhuma das suas respostas, mas apenas adicionou um pouco, funcionou! Aqui meu código:
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 );
Só adicionei /wp-login.php
em comparação com a resposta de @ Matt, mas para mim tem sido a chave. Espero que ajude! :)
**EDITAR:
Detectei um ERRO quando você está no FORCE wordpress para navegar no HTTPS. Este método não funciona porque o redirecionamento está no HTTP. Para corrigir o problema, mudei a função. Este é o resultado:
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 );
Eu verifico o protocolo e, em seguida, eu apaguei ' esc_url
' e acrescentou o protocolo correto: $protocol://
. Também mudei o ""
.
Eu sou baseado nesta página .