Wordpress隐藏wp-admin管理与Nginx


Wordpress Hide wp-admin to admin with Nginx

我想将example.com/wp-admin重定向到我的索引,并使WP-Admin通过example.com/admin之类的东西可访问。

我在apache中这样做了,但切换到nginx后,我不知道如何做到这一点?

有没有一种方法可以做到这一点,而不改变任何wordpress文件,但改变nginx配置?
还需要访问example.com/wp-admin/index.php作为example.com/admin/index.php, example.com/wp-admin/posts.php作为example.com/admin/posts.php等。

在我看来,如果你使用插件,它会发现WordPress的安全漏洞。

您可以使用以下步骤创建自己的登录URL admin或else,如下所示:

1)。为wp-confing.php添加常量

define('WP_ADMIN_DIR', 'secret-folder');
define( 'ADMIN_COOKIE_PATH', SITECOOKIEPATH . WP_ADMIN_DIR);

2)。将下面的过滤器添加到functions.php

add_filter('site_url',  'wpadmin_filter', 10, 3);
function wpadmin_filter( $url, $path, $orig_scheme ) {
  $old  = array( "/(wp-admin)/");
  $admin_dir = WP_ADMIN_DIR;
  $new  = array($admin_dir);
  return preg_replace( $old, $new, $url, 1);
}

3)。如果您使用的是Apache

,请将下面一行添加到.htaccess文件中
RewriteRule ^secret-folder/(.*) wp-admin/$1?%{QUERY_STRING} [L]

编辑Nginx虚拟主机文件,并放置以下内容:

location ~* /admin/ {
  rewrite ^/admin/(.*) /wp-admin/$1 last;
}

完成! !

现在你的管理URL将是:http://www.yourdomain.com/secret-folder/

和下面的代码将限制URL: site.com/wp-admin

add_action('login_form','redirect_wp_admin');
function redirect_wp_admin(){
  $redirect_to = $_SERVER['REQUEST_URI'];
  if(count($_REQUEST)> 0 && array_key_exists('redirect_to', $_REQUEST)){
    $redirect_to = $_REQUEST['redirect_to'];
    $check_wp_admin = stristr($redirect_to, 'wp-admin');
    if($check_wp_admin){
      wp_safe_redirect( '404.php' );
    }
  }
}

编辑:编辑Nginx虚拟主机文件,输入以下内容:

location ~* /admin/ {
  rewrite ^/admin/(.*) /wp-admin/$1 last;
}

如果你想把url从index.php重定向到admin

server {
  index index.php;
  if ($request_uri ~* "^(.*/)index'.php$") {
    return 301 $1;
  }
  location = /admin/index.php {
    return 301 $scheme://www.example.com/admin/;
  }
}
这样做的另一个好处是nginx返回的速度比重写快。

您的意思是更改wp-admin的url。然后你可以使用下面提到的插件Wordpress链接

安装插件后,在settings->Permalink下,我们可以将WP-admin页面段改为我们需要的内容。

要更改admin url,请尝试使用以下插件https://wordpress.org/plugins/wordfence/