WooCommerce-登录后重定向到上一页

时间:2019-05-24 11:58:53

标签: php wordpress woocommerce

我一直在寻找可以处理它几个小时的插件和片段,但没有成功。每个答案都不适合我。我在菜单中有“登录”链接,转到WooCommerce的“我的帐户”页面,该页面显示登录表单。我希望客户返回到成功登录后单击“登录”链接的页面。

wp_get_referer()不返回任何内容,并且$_SERVER["HTTP_REFERER"]返回我的帐户页面(如果放置在挂钩到woocommerce_login_redirect的函数中(我使用PHP调试控制台进行检查)。

这是我的代码:

// Redirect user after login.
add_filter( 'woocommerce_login_redirect', 'wc_custom_user_redirect', 10, 2 );
function wc_custom_user_redirect( $redirect, $user ) {
    // Get the first of all the roles assigned to the user
    $role = $user->roles[0];
    $dashboard = admin_url();       

    if (in_array($role, array('administrator', 'shop_manager', 'editor', 'author', 'contributor'))) {
        $redirect = $dashboard;         
    } elseif (in_array($role, array('customer', 'subscriber'))) {
        $redirect = $_SERVER["HTTP_REFERER"];          
    } else {
        $redirect = $_SERVER["HTTP_REFERER"];       
    }

    return $redirect;

}

这是我使用的过滤器出现在WooCommerce代码中的地方:

/** 
   * Process the login form. 
   */ 
  public static function process_login() { 
      $nonce_value = isset( $_POST['_wpnonce'] ) ? $_POST['_wpnonce'] : ''; 
      $nonce_value = isset( $_POST['woocommerce-login-nonce'] ) ? $_POST['woocommerce-login-nonce'] : $nonce_value; 

      if ( ! empty( $_POST['login'] ) && wp_verify_nonce( $nonce_value, 'woocommerce-login' ) ) { 

          try { 
              $creds = array( 
                  'user_password' => $_POST['password'],  
                  'remember' => isset( $_POST['rememberme'] ),  
 ); 

              $username = trim( $_POST['username'] ); 
              $validation_error = new WP_Error(); 
              $validation_error = apply_filters( 'woocommerce_process_login_errors', $validation_error, $_POST['username'], $_POST['password'] ); 

              if ( $validation_error->get_error_code() ) { 
                  throw new Exception( '<strong>' . __( 'Error:', 'woocommerce' ) . '</strong> ' . $validation_error->get_error_message() ); 
              } 

              if ( empty( $username ) ) { 
                  throw new Exception( '<strong>' . __( 'Error:', 'woocommerce' ) . '</strong> ' . __( 'Username is required.', 'woocommerce' ) ); 
              } 

              if ( is_email( $username ) && apply_filters( 'woocommerce_get_username_from_email', true ) ) { 
                  $user = get_user_by( 'email', $username ); 

                  if ( isset( $user->user_login ) ) { 
                      $creds['user_login'] = $user->user_login; 
                  } else { 
                      throw new Exception( '<strong>' . __( 'Error:', 'woocommerce' ) . '</strong> ' . __( 'A user could not be found with this email address.', 'woocommerce' ) ); 
                  } 
              } else { 
                  $creds['user_login'] = $username; 
              } 

              // On multisite, ensure user exists on current site, if not add them before allowing login. 
              if ( is_multisite() ) { 
                  $user_data = get_user_by( 'login', $username ); 

                  if ( $user_data && ! is_user_member_of_blog( $user_data->ID, get_current_blog_id() ) ) { 
                      add_user_to_blog( get_current_blog_id(), $user_data->ID, 'customer' ); 
                  } 
              } 

              // Perform the login 
              $user = wp_signon( apply_filters( 'woocommerce_login_credentials', $creds ), is_ssl() ); 

              if ( is_wp_error( $user ) ) { 
                  $message = $user->get_error_message(); 
                  $message = str_replace( '<strong>' . esc_html( $creds['user_login'] ) . '</strong>', '<strong>' . esc_html( $username ) . '</strong>', $message ); 
                  throw new Exception( $message ); 
              } else { 

                  if ( ! empty( $_POST['redirect'] ) ) { 
                      $redirect = $_POST['redirect']; 
                  } elseif ( wp_get_referer() ) { 
                      $redirect = wp_get_referer(); 
                  } else { 
                      $redirect = wc_get_page_permalink( 'myaccount' ); 
                  } 

                  wp_redirect( apply_filters( 'woocommerce_login_redirect', $redirect, $user ) ); 
                  exit; 
              } 
          } catch ( Exception $e ) { 
              wc_add_notice( apply_filters( 'login_errors', $e->getMessage() ), 'error' ); 
              do_action( 'woocommerce_login_failed' ); 
          } 
      } 
  } 

3 个答案:

答案 0 :(得分:1)

请尝试以下代码,希望对您有所帮助。  将以下代码粘贴到当前活动主题 functions.php 文件中。

// start global session for saving the referer url
function start_session() {
    if(!session_id()) {
        session_start();
    }
}
add_action('init', 'start_session', 1);

// get  referer url and save it 
function redirect_url() {
    if (! is_user_logged_in()) {
        $_SESSION['referer_url'] = wp_get_referer();
    } else {
        session_destroy();
    }
}
add_action( 'template_redirect', 'redirect_url' );

//login redirect 
function login_redirect() {
    if (isset($_SESSION['referer_url'])) {
        wp_redirect($_SESSION['referer_url']);
    } else {
        wp_redirect(home_url());
    }
}
add_filter('woocommerce_login_redirect', 'login_redirect', 1100, 2);

答案 1 :(得分:0)

我们必须使用wordpress引荐来源网址功能

例如, 通过单击添加到购物车按钮或任何按钮以存储先前的URL,在会话或隐藏字段中设置引荐来源网址。登录或注册成功后,请添加Woocommerce成功登录重定向到该URL。

关于Referrer功能,请阅读以下内容:

https://codex.wordpress.org/Function_Reference/wp_get_referer

Woocommerce登录重定向:

https://stackoverflow.com/questions/29342186/woocommerce-after-login-redirect

答案 2 :(得分:0)

这将解决您的问题


add_filter( 'woocommerce_login_redirect', function(){
   
       wp_safe_redirect(wp_get_referer());

}, 10, 2 );

相关问题