我想将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/