Hello to friends
In principle, the problem is not the plugin, but the problem with WordPress. Having a lot of friends with different plugins has this problem. With different methods, the plugin can be matched with WordPress. Below I provide an easy way to solve the problem, but 100% is caused by plugins that require access to the htaccess file. WordPress rewrites the relevant rules in the htaccess file each time it’s called, so each code in this section is rewritten or erased. If you’re a little familiar with php, you can easily fix this problem. Here I block access to WordPress, as well as all extensions that require the htacess file, and only accesses the file when the plugin needs the htaccess file, and again after the changes are made, access to this file is blocked.
Method: This method is only for beginner friends and is not a great way to block WordPress and other plugins access to the htaccess file (0444, that is, only readable)
Find the hide-login.php file from the list of file extensions and select the edit option and replace the code with this file.
/////////////////////////hide-login.php/////////////////////////////////
<?php
/*
Plugin Name: Hide Login+
Description: This plugin allows you to create custom URLs for user’s Log in, Log out, Sign up and Admin page.
Author: Mohammad Hossein Aghanabi
Version: 3.5.1
Author URI: https://koder.io
*/
/*
This is a new version of Stealth Login plguin by skullbit
*/
/**
* [hideOptions Sets plugin default options on activation]
* @return [void]
*/
function hideOptions()
{
delete_option(“hide_login_slug”);
delete_option(“hide_admin_slug”);
delete_option(“hide_logout_slug”);
delete_option(“hide_register_slug”);
delete_option(“hide_forgot_slug”);
delete_option(“hide_wplogin”);
delete_option(“hide_wpadmin”);
delete_option(“hide_rules”);
add_option(“hide_login_slug”, “login”);
add_option(“hide_admin_slug”, “”);
add_option(“hide_logout_slug”, “logout”);
add_option(“hide_register_slug”, “register”);
add_option(“hide_forgot_slug”, “forgot”);
add_option(“hide_wplogin”, 0);
add_option(“hide_wpadmin”, 0);
add_option(“hide_rules”, “”);
}
register_activation_hook( __FILE__ , ‘hideOptions’ );
define(“LOGIN_SLUG”, get_option(“hide_login_slug”, “login”));
define(“ADMIN_SLUG”, get_option(“hide_admin_slug”));
define(“LOGOUT_SLUG”, get_option(“hide_logout_slug”, “logout”));
define(“REGISTER_SLUG”, get_option(“hide_register_slug”, “register”));
define(“FORGOT_SLUG”, get_option(“hide_forgot_slug”, “forgot”));
/**
* [_setup controls access over wp-login.php, logout and wp-admin URLs]
* @return [void]
*/
function _setup() {
global $current_user;
if(get_option(“hide_wplogin”) == 1) {
if(requestURI() == ‘wp-login.php’) {
wp_redirect(get_option(‘siteurl’), 302);
exit;
}
}
if(requestURI() == LOGOUT_SLUG) {
if(ADMIN_SLUG != “”)
setcookie( is_ssl() ? SECURE_AUTH_COOKIE : AUTH_COOKIE, ‘ ‘, time() – YEAR_IN_SECONDS, SITECOOKIEPATH . ADMIN_SLUG, COOKIE_DOMAIN );
wp_logout();
wp_redirect(get_option(‘siteurl’));
exit;
}
if(get_option(“hide_wpadmin”) == 1 && !user_can( $current_user, “edit_posts” )) {
if(requestURI() == ‘wp-admin’) {
wp_redirect(get_option(‘siteurl’));
exit;
}
}
}
add_action(‘init’, ‘_setup’);
// Hooked to WordPress for changing cookie on new admin page
function setAdminCookie($auth_cookie, $expire) {
setcookie(is_ssl() ? SECURE_AUTH_COOKIE : AUTH_COOKIE, $auth_cookie, $expire, SITECOOKIEPATH . ADMIN_SLUG, COOKIE_DOMAIN, is_ssl(), true);
}
// Changes wp-admin slug everywhere
function changeAdminURL( $url ) {
return str_replace(“wp-admin”, ADMIN_SLUG, $url);
}
if(ADMIN_SLUG != “”) {
add_action(“set_auth_cookie”, “setAdminCookie”, 10, 2);
add_filter(‘site_url’, ‘changeAdminURL’, 10, 1);
}
/**
* [requestURI Returns URL path]
* @return string $part
*/
function requestURI()
{
$part = parse_url($_SERVER[‘REQUEST_URI’], PHP_URL_PATH);
$part = trim($part, “/”);
$part = strtolower($part);
$part = explode(“/”, $part);
return $part[0];
}
/**
* [addPanel Adds Hide Login+ menu]
*/
function addPanel()
{
add_menu_page(‘Hide Login+’, ‘Hide Login+’, ‘manage_options’, ‘hide_settings’, ‘hideSettings’);
}
add_action(‘admin_menu’,’addPanel’);
/**
* [updateSettings Saves changes on submitting form]
*/
function updateSettings()
{
if( isset($_POST[‘action’]) && $_POST[‘action’] == ‘hide_login_update’ ) {
$_GET[‘type’] = “updated”;
$_GET[‘id’] = 0;
$error = false;
array_walk($_POST, function(&$item, $key) use (&$error)
{
if(substr($key, 0, 5) == ‘hide_’ && !$error) {
$item = preg_replace(“/[^A-Za-z0-9_\-]/”, “”, $item);
if(strlen($item) < 1 && $key != ‘hide_admin_slug’)
{
$error = true;
}
$item = substr($item, 0, 24);
}
});
if(weHaveError($error)) {
$type = ‘error’;
$id = 0;
wp_safe_redirect(“/”.(ADMIN_SLUG != “”) ? ADMIN_SLUG : “wp-admin”.”/admin.php?page=hide_settings&type=$type&id=$id”);
exit;
}
update_option(“hide_login_slug”, $_POST[‘hide_login_slug’]);
update_option(“hide_logout_slug”, $_POST[‘hide_logout_slug’]);
update_option(“hide_forgot_slug”, $_POST[‘hide_forgot_slug’]);
update_option(“hide_admin_slug”, $_POST[‘hide_admin_slug’]);
update_option(“hide_wplogin”, in_array($_POST[‘hide_wplogin’], range(0,1)) ? $_POST[‘hide_wplogin’] : 0 );
if(get_option(‘hide_admin_slug’) != “”)
update_option(“hide_wpadmin”, in_array($_POST[‘hide_wpadmin’], range(0,1)) ? $_POST[‘hide_wpadmin’] : 0 );
if(get_option(‘users_can_register’))
update_option(“hide_register_slug”, $_POST[‘hide_register_slug’]);
hideLogin();
}
}
add_action(“admin_init”, “updateSettings”);
// Changes logout URL slug everywhere
add_filter(‘logout_url’, function ($url, $redirect) {
return home_url(“/”.LOGOUT_SLUG);
}, 10, 2);
// Changes login URL slug everywhere
add_filter(‘login_url’, function ($url, $redirect) {
return home_url(“/”.LOGOUT_SLUG);
}, 10, 2 );
// Changes registration URL slug everywhere
add_filter(‘register’,function ($url) {
return str_replace(site_url(‘wp-login.php?action=register’, ‘login’), site_url(REGISTER_SLUG, ‘login’), $url);
});
// Changes lostpassword URL slug everywhere
add_filter(‘lostpassword_url’, function ($url) {
return str_replace(‘?action=lostpassword’,”,str_replace(network_site_url(‘wp-login.php’, ‘login’), site_url(FORGOT_SLUG, ‘login’), $url));
});
/**
* [changeURLs Modifies all related forms on initialization accroding to their new set URL]
* @return void $form
*/
function changeURLs()
{
$array = array(‘register_form’ => REGISTER_SLUG,
‘lostpassword_form’ => FORGOT_SLUG,
‘resetpass_form’ => FORGOT_SLUG,
‘login_form’ => LOGIN_SLUG
);
$slug = $array[current_filter()];
$form = ob_get_contents();
$form = preg_replace( “/wp-login\.php([^\”]*)/”, $slug.’$1′, $form);
ob_get_clean();
echo $form;
}
add_action( ‘login_form’, ‘changeURLs’);
add_action( ‘register_form’, ‘changeURLs’);
add_action( ‘lostpassword_form’, ‘changeURLs’);
add_action( ‘resetpass_form’, ‘changeURLs’);
// Where to redirect after a successful login, default redirection is wp-admin
add_action(‘login_redirect’, function () {
global $redirect_to;
if (!isset($_GET[‘redirect_to’])) {
return get_option(‘siteurl’).”/”.(ADMIN_SLUG != “” ? ADMIN_SLUG : “wp-admin”);
}
else
return $redirect_to;
});
// Redirection URL after submitting lostpassword form
add_filter(‘lostpassword_redirect’, function() {
return site_url(LOGIN_SLUG.”?checkemail=confirm” );
});
// Redirection URL after submitting registration form
add_filter(‘registration_redirect’, function() {
return site_url(LOGIN_SLUG.”?checkemail=registered” );
});
/**
* [hideLogin Handles new RewriteRules as well as custom ones]
*/
function hideLogin()
{
global $wp_rewrite;
chmod(ABSPATH.’/.htaccess’, 0777);
// Backup original .htaccess file
if (!file_exists(ABSPATH.’/.htaccess.backup’)) {
copy(ABSPATH.’/.htaccess’, ABSPATH.’/.htaccess.backup’);
}
add_rewrite_rule( get_option(“hide_login_slug”, “login”).’/?$’, ‘wp-login.php’, ‘top’ );
if(get_option(“hide_admin_slug”) != “”)
add_rewrite_rule(get_option(“hide_admin_slug”).’/(.*)’, “wp-admin/$1?%{QUERY_STRING}”, ‘top’);
if(get_option(‘users_can_register’))
add_rewrite_rule( get_option(“hide_register_slug”, “register”).’/?$’, ‘wp-login.php?action=register’, ‘top’ );
add_rewrite_rule( get_option(“hide_forgot_slug”, “forgot”).’/?$’, ‘wp-login.php?action=lostpassword’, ‘top’ );
$str = ”;
if(get_option(‘hide_admin_slug’) != ”)
{
$forerules = array(“RewriteRule” => ‘^’.get_option(‘hide_admin_slug’).’$ ‘.’/ [R,L]’);
foreach ($forerules as $cmd => $rules) {
if(is_array($rules)) {
foreach ($rules as $rule) {
$str .= “$cmd $rule\r\n”;
}
}
else
$str .= “$cmd $rules\r\n”;
}
}
add_filter(‘mod_rewrite_rules’, function ($rules) use ($str){
$pattern = “@(^\QRewriteRule ^index\.php$ – [L]\E\s)@m”;
$rules = preg_replace($pattern, “$1”.$str, $rules);
update_option(“hide_rules”, $rules);
return $rules;
});
$wp_rewrite->flush_rules(true);
chmod(ABSPATH.’/.htaccess’, 0444);
}
/**
* [showMsg Displays message on form submit]
* @param [integer] $id [Text ID]
* @param [string] $type [Type of message]
* @return [string] $display [HTML output]
*/
function showMsg($id, $type)
{
$messages = array(‘error’ => array(0 => __(‘Don\’t leave some fields empty.’, ‘hidelogin’)),
‘updated’ => array(0 => __(‘Settings Updated’,’hidelogin’)));
$display = ‘<div id=”message” class=”‘.$type.’ fade”><p>‘ . $messages[$type][$id] . ‘</p></div>’;
return $display;
}
/**
* [hideSettings Shows settings page]
*/
function hideSettings()
{
if(isset($_GET[‘type’]) && isset($_GET[‘id’]))
echo showMsg($_GET[‘id’], $_GET[‘type’]);
require_once(dirname(__file__).’/admin.php’);
}
/**
* [weHaveError Checks if there is any error out there :|]
* @param [bool] $var [Boolean value]
* @return [bool]
*/
function weHaveError($var)
{
return $var;
}
/**
* [_deactivate Will rollback all affected changes to their defaults]
*/
function _deactivate()
{
$htac_url = ABSPATH.’/.htaccess’;
chmod(ABSPATH.’/.htaccess’, 0777);
remove_action( ‘generate_rewrite_rules’, ‘hideLogin’ );
delete_option(“hide_login_slug”);
delete_option(“hide_admin_slug”);
delete_option(“hide_logout_slug”);
delete_option(“hide_register_slug”);
delete_option(“hide_forgot_slug”);
delete_option(“hide_wplogin”);
delete_option(“hide_wpadmin”);
delete_option(“hide_rules”);
$GLOBALS[‘wp_rewrite’]->flush_rules(true);
chmod(ABSPATH.’/.htaccess’, 0444);
}
register_deactivation_hook(__FILE__ , ‘_deactivate’);
/**
* [redirectOnDeactivation Redirects after deactivation to prevent intrruption of old admin slug]
* @return [void]
*/
function redirectOnDeactivation($plugin) {
if($plugin == ‘hide-login/hide-login.php’)
{
$current = get_option( ‘active_plugins’, array() );
$key = array_search( $plugin, $current );
unset( $current[ $key ] );
update_option(‘active_plugins’, $current);
exit(wp_safe_redirect(‘/wp-admin/plugins.php?deactivate=true&plugin_status=all&paged=1&s=’));
}
}
add_action(‘deactivated_plugin’, ‘redirectOnDeactivation’, 10, 1);
?>
Hi!
We are testing this plugin for our wordpress 4.6.1 site.
It works good so far. However, when we test the “recover password” feature of the wordpress login, the recover link takes you to the home page.
Is there any way to fix this or work around it?
Thanks
Luis
I have tested this plugin twice. Both times it failed. It will lock you out of your site, resulting in having to delete the file folder through an FTP client in order to get the site login information back again.
I do not recommend this plugin with version 4.5.3 unless you want to run through the errors to gain access to your admin panel.
]]>Tested network activating it and it wouldn’t let me deactivate. Have to delete from cpanel.
]]>I can’t get back into my site – the new link I gave it is not working.
Is there a problem running this with Wordfence?
Funny thing is that I’m getting emails saying that logins are failing – to wp-admin. I can’t even bring up wp-admin.
How do I get back into my site? I have direct access to the database – is there a way to de-activate this plugin?
]]>redirects don’t work, can’t log into site at all.
To recover: edit .htaccess file to remove the login/logout/wpadmin redirects, then rename the hide-login subdir in your plugins directory to disable the plugin. You can then login to the site admin panel and delete this plugin.
]]>Hello,
Thanks for plugin, great job ??
Any ideas why submit button is missing after installing this plugin?
I was deleting him by ftp, install again and still missing.
https://f2pzone.pl/panel_wydawcy/
I will be grateful for your help
Hi,
Thanks for the plugin. I know it doesn’t support MU but I’ve figured out how to set it up; it works so far. Two things I’ve changed to make it work that don’t relate to MU.
1. Probably should be LOGIN_SLUG, r?
add_filter('login_url', function ($url, $redirect) {
return home_url("/".LOGOUT_SLUG);
}, 10, 2 );
2. When FORCE_SSL_ADMIN is set to true get_option will still return http version of URL thus resulting in a loop; solved by removing get_option(‘siteurl’) from the beginning.
add_action('login_redirect', function () {
global $redirect_to;
if (!isset($_GET['redirect_to'])) {
return get_option('siteurl')."/".(ADMIN_SLUG != "" ? ADMIN_SLUG : "wp-admin");
}
else
return $redirect_to;
});
]]>
This plugin works in multisite?
]]>Admin slug is in blank but I can’t access to wp-admin url and even if I put a slug in Admin slug it wont work. any ideas?
]]>If you’re seeing the following error message in your dashboard
Notice: Undefined index: action in wp-content/plugins/hide-login/hide-login.php on line 98
Here is a solution. The problem is due to the plugin looking for a post variable called action. As no post variables are available when logging into the dashboard, we need to change this line from:
if( $_POST['action'] == 'hide_login_update' )
to
if( isset ( $_POST['action']) && $_POST['action'] == 'hide_login_update' )
This checks to first see if the action variable exists in the post array and then if it is set to ‘hide_login_update’. If one or both return false, the conditions inside the if loop will not run. Since the function is for updating options and we are not on the options page anyways, this is good. This will fix the issue for you and remove the error message.
]]>Hi
I am using Hide login + plugin.
It was working with 3.9.3, but having problem with 4.1.Also content editor behaves inadequately. word spacing becames wordless after update action
Please assist me
Thanks
]]>please update your plugin
]]>After updating to WordPress 3.8.x myself and my clients cannot login to the dashboard when using Hide Login+
I know its this plugin that is causing the login to constantly though the login back to the login in page. As it is the only plugin active and when deactivated and the 2 defines are removed form the config file, it works again.
Have you come across this before and will it be plugged? If not then I will start looking for an alternative.
]]>Will this ever have multi-site support?
I was not able to get it to work on mine.
]]>I need only change logout slug function from this plugin. Can anyone tell me what to insert in theme functions.php?
]]>I am having an issue when running the site from a directory. I get redirected to the wrong URL. Below are examples
When trying to access admin (https://www.test.com/test/admin/) I get redirect to login page without the directory (https://www.test.com/login)
When logging in I get redirect to ‘https://www.test.com/test/test/admin/’
These issues make the site unusable when running from a directory.
Could you please rectify these issues.
]]>Hi all users,
New version of plugin released [v3.1] that solved most of problems as Server internal error
and fatal error
caused by a function. Also the name changed from Hide Login to Hide Login+. Hope that it meets your needs.
Feed backs are welcome
]]>After i activate this plugin i take this error when i try to acces my wp-admin. I have delet this from ftp and same error.
Internal Server Error
The server encountered an internal error or misconfiguration and was unable to complete your request.
Please contact the server administrator, [email protected] and inform them of the time the error occurred, and anything you might have done that may have caused the error.
More information about this error may be available in the server error log.
Additionally, a 500 Internal Server Error error was encountered while trying to use an ErrorDocument to handle the request.
What can i resolv this error?
]]>Use FileZilla or another Ftp Client.
Step 1: Find your .htacess file and right click it to edit.
Step 2: Over Right entire trxt with this…
AddType application/java .class
AddType application/javascript .js2
AddType application/json .json
AddType application/msword .doc .docx
AddType application/pdf .pdf
AddType application/vnd.ms-access .mdb
AddType application/vnd.ms-excel .xla .xls .xlsx .xlt .xlw
AddType application/vnd.ms-fontobject .eot
AddType application/vnd.ms-powerpoint .pot .pps .ppt .pptx
AddType application/vnd.ms-project .mpp
AddType application/vnd.ms-write .wri
AddType application/vnd.oasis.opendocument.chart .odc
AddType application/vnd.oasis.opendocument.database .odb
AddType application/vnd.oasis.opendocument.formula .odf
AddType application/vnd.oasis.opendocument.graphics .odg
AddType application/vnd.oasis.opendocument.presentation .odp
AddType application/vnd.oasis.opendocument.spreadsheet .ods
AddType application/vnd.oasis.opendocument.text .odt
AddType application/x-font-otf .otf
AddType application/x-font-ttf .ttf .ttc
AddType application/x-gzip .gz .gzip
AddType application/x-javascript .js
AddType application/x-msdownload .exe
AddType application/x-shockwave-flash .swf
AddType application/x-tar .tar
AddType application/zip .zip
AddType audio/midi .mid .midi
AddType audio/mpeg .mp3 .m4a
AddType audio/ogg .ogg
AddType audio/wav .wav
AddType audio/wma .wma
AddType audio/x-realaudio .ra .ram
AddType image/bmp .bmp
AddType image/gif .gif
AddType image/jpeg .jpg .jpeg .jpe
AddType image/png .png
AddType image/svg+xml .svg .svgz
AddType image/tiff .tif .tiff
AddType image/x-icon .ico
AddType text/css .css
AddType text/html .html .htm
AddType text/javascript .js3
AddType text/plain .txt
AddType text/richtext .rtf .rtx
AddType text/x-component .htc
AddType text/x-js .js4
AddType text/xml .xml
AddType text/xsd .xsd
AddType text/xsl .xsl
AddType video/asf .asf .asx .wax .wmv .wmx
AddType video/avi .avi
AddType video/divx .divx
AddType video/mp4 .mp4 .m4v
AddType video/mpeg .mpeg .mpg .mpe
AddType video/quicktime .mov .qt
# BEGIN W3TC Browser Cache
<IfModule mod_mime.c>
AddType text/css .css
AddType text/x-component .htc
AddType application/x-javascript .js
AddType application/javascript .js2
AddType text/javascript .js3
AddType text/x-js .js4
AddType text/html .html .htm
AddType text/richtext .rtf .rtx
AddType image/svg+xml .svg .svgz
AddType text/plain .txt
AddType text/xsd .xsd
AddType text/xsl .xsl
AddType text/xml .xml
AddType video/asf .asf .asx .wax .wmv .wmx
AddType video/avi .avi
AddType image/bmp .bmp
AddType application/java .class
AddType video/divx .divx
AddType application/msword .doc .docx
AddType application/vnd.ms-fontobject .eot
AddType application/x-msdownload .exe
AddType image/gif .gif
AddType application/x-gzip .gz .gzip
AddType image/x-icon .ico
AddType image/jpeg .jpg .jpeg .jpe
AddType application/json .json
AddType application/vnd.ms-access .mdb
AddType audio/midi .mid .midi
AddType video/quicktime .mov .qt
AddType audio/mpeg .mp3 .m4a
AddType video/mp4 .mp4 .m4v
AddType video/mpeg .mpeg .mpg .mpe
AddType application/vnd.ms-project .mpp
AddType application/x-font-otf .otf
AddType application/vnd.oasis.opendocument.database .odb
AddType application/vnd.oasis.opendocument.chart .odc
AddType application/vnd.oasis.opendocument.formula .odf
AddType application/vnd.oasis.opendocument.graphics .odg
AddType application/vnd.oasis.opendocument.presentation .odp
AddType application/vnd.oasis.opendocument.spreadsheet .ods
AddType application/vnd.oasis.opendocument.text .odt
AddType audio/ogg .ogg
AddType application/pdf .pdf
AddType image/png .png
AddType application/vnd.ms-powerpoint .pot .pps .ppt .pptx
AddType audio/x-realaudio .ra .ram
AddType application/x-shockwave-flash .swf
AddType application/x-tar .tar
AddType image/tiff .tif .tiff
AddType application/x-font-ttf .ttf .ttc
AddType audio/wav .wav
AddType audio/wma .wma
AddType application/vnd.ms-write .wri
AddType application/vnd.ms-excel .xla .xls .xlsx .xlt .xlw
AddType application/zip .zip
</IfModule>
<IfModule mod_expires.c>
ExpiresActive On
ExpiresByType text/css A31536000
ExpiresByType text/x-component A31536000
ExpiresByType application/x-javascript A31536000
ExpiresByType application/javascript A31536000
ExpiresByType text/javascript A31536000
ExpiresByType text/x-js A31536000
ExpiresByType text/html A3600
ExpiresByType text/richtext A3600
ExpiresByType image/svg+xml A3600
ExpiresByType text/plain A3600
ExpiresByType text/xsd A3600
ExpiresByType text/xsl A3600
ExpiresByType text/xml A3600
ExpiresByType video/asf A31536000
ExpiresByType video/avi A31536000
ExpiresByType image/bmp A31536000
ExpiresByType application/java A31536000
ExpiresByType video/divx A31536000
ExpiresByType application/msword A31536000
ExpiresByType application/vnd.ms-fontobject A31536000
ExpiresByType application/x-msdownload A31536000
ExpiresByType image/gif A31536000
ExpiresByType application/x-gzip A31536000
ExpiresByType image/x-icon A31536000
ExpiresByType image/jpeg A31536000
ExpiresByType application/json A31536000
ExpiresByType application/vnd.ms-access A31536000
ExpiresByType audio/midi A31536000
ExpiresByType video/quicktime A31536000
ExpiresByType audio/mpeg A31536000
ExpiresByType video/mp4 A31536000
ExpiresByType video/mpeg A31536000
ExpiresByType application/vnd.ms-project A31536000
ExpiresByType application/x-font-otf A31536000
ExpiresByType application/vnd.oasis.opendocument.database A31536000
ExpiresByType application/vnd.oasis.opendocument.chart A31536000
ExpiresByType application/vnd.oasis.opendocument.formula A31536000
ExpiresByType application/vnd.oasis.opendocument.graphics A31536000
ExpiresByType application/vnd.oasis.opendocument.presentation A31536000
ExpiresByType application/vnd.oasis.opendocument.spreadsheet A31536000
ExpiresByType application/vnd.oasis.opendocument.text A31536000
ExpiresByType audio/ogg A31536000
ExpiresByType application/pdf A31536000
ExpiresByType image/png A31536000
ExpiresByType application/vnd.ms-powerpoint A31536000
ExpiresByType audio/x-realaudio A31536000
ExpiresByType image/svg+xml A31536000
ExpiresByType application/x-shockwave-flash A31536000
ExpiresByType application/x-tar A31536000
ExpiresByType image/tiff A31536000
ExpiresByType application/x-font-ttf A31536000
ExpiresByType audio/wav A31536000
ExpiresByType audio/wma A31536000
ExpiresByType application/vnd.ms-write A31536000
ExpiresByType application/vnd.ms-excel A31536000
ExpiresByType application/zip A31536000
</IfModule>
<IfModule mod_deflate.c>
<IfModule mod_headers.c>
Header append Vary User-Agent env=!dont-vary
</IfModule>
AddOutputFilterByType DEFLATE text/css text/x-component application/x-javascript application/javascript text/javascript text/x-js text/html text/richtext image/svg+xml text/plain text/xsd text/xsl text/xml image/x-icon application/json
<IfModule mod_mime.c>
# DEFLATE by extension
AddOutputFilter DEFLATE js css htm html xml
</IfModule>
</IfModule>
<FilesMatch "\.(css|htc|js|js2|js3|js4|CSS|HTC|JS|JS2|JS3|JS4)$">
FileETag MTime Size
<IfModule mod_headers.c>
Header set Pragma "public"
Header append Cache-Control "public, must-revalidate, proxy-revalidate"
Header set X-Powered-By "W3 Total Cache/0.9.2.8"
</IfModule>
</FilesMatch>
<FilesMatch "\.(html|htm|rtf|rtx|svg|svgz|txt|xsd|xsl|xml|HTML|HTM|RTF|RTX|SVG|SVGZ|TXT|XSD|XSL|XML)$">
FileETag MTime Size
<IfModule mod_headers.c>
Header set Pragma "public"
Header append Cache-Control "public, must-revalidate, proxy-revalidate"
Header set X-Powered-By "W3 Total Cache/0.9.2.8"
</IfModule>
</FilesMatch>
<FilesMatch "\.(asf|asx|wax|wmv|wmx|avi|bmp|class|divx|doc|docx|eot|exe|gif|gz|gzip|ico|jpg|jpeg|jpe|json|mdb|mid|midi|mov|qt|mp3|m4a|mp4|m4v|mpeg|mpg|mpe|mpp|otf|odb|odc|odf|odg|odp|ods|odt|ogg|pdf|png|pot|pps|ppt|pptx|ra|ram|svg|svgz|swf|tar|tif|tiff|ttf|ttc|wav|wma|wri|xla|xls|xlsx|xlt|xlw|zip|ASF|ASX|WAX|WMV|WMX|AVI|BMP|CLASS|DIVX|DOC|DOCX|EOT|EXE|GIF|GZ|GZIP|ICO|JPG|JPEG|JPE|JSON|MDB|MID|MIDI|MOV|QT|MP3|M4A|MP4|M4V|MPEG|MPG|MPE|MPP|OTF|ODB|ODC|ODF|ODG|ODP|ODS|ODT|OGG|PDF|PNG|POT|PPS|PPT|PPTX|RA|RAM|SVG|SVGZ|SWF|TAR|TIF|TIFF|TTF|TTC|WAV|WMA|WRI|XLA|XLS|XLSX|XLT|XLW|ZIP)$">
FileETag MTime Size
<IfModule mod_headers.c>
Header set Pragma "public"
Header append Cache-Control "public, must-revalidate, proxy-revalidate"
Header set X-Powered-By "W3 Total Cache/0.9.2.8"
</IfModule>
</FilesMatch>
# END W3TC Browser Cache
# BEGIN W3TC Page Cache core
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteCond %{HTTPS} =on
RewriteRule .* - [E=W3TC_SSL:_ssl]
RewriteCond %{SERVER_PORT} =443
RewriteRule .* - [E=W3TC_SSL:_ssl]
RewriteCond %{HTTP:Accept-Encoding} gzip
RewriteRule .* - [E=W3TC_ENC:_gzip]
RewriteCond %{REQUEST_METHOD} !=POST
RewriteCond %{QUERY_STRING} =""
RewriteCond %{REQUEST_URI} \/$
RewriteCond %{HTTP_COOKIE} !(comment_author|wp\-postpass|w3tc_logged_out|wordpress_logged_in) [NC]
RewriteCond "%{DOCUMENT_ROOT}/wp-content/cache/page_enhanced/%{HTTP_HOST}/%{REQUEST_URI}/_index%{ENV:W3TC_SSL}.html%{ENV:W3TC_ENC}" -F
RewriteRule .* "/wp-content/cache/page_enhanced/%{HTTP_HOST}/%{REQUEST_URI}/_index%{ENV:W3TC_SSL}.html%{ENV:W3TC_ENC}" [L]
</IfModule>
# END W3TC Page Cache core
# BEGIN WordPress
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteRule ^index\.php$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.php [L]
</IfModule>
# END WordPress
[Please post large files inside backticks or use the code button.]
Step 3: Save and refresh, then test.
]]>after install, the admin throws a 500 internal server error due to the code added to the htaccess…
]]>Al tratar de activar el plugin (https://www.ads-software.com/extend/plugins/hide-login/) se bloqueó y ya no puedo entrar en mi blog, POR FAVOR NO LO INSTALEN SIN PRIMERO INFORMARSE.
Necesito ayuda, ya entre al cpanel y borré el plugin pero sigo sin poder entrar en mi blog.
Cuando pongo https://www.miblog.com/wp-admin (url ficticia, solo es a modo de ejemplo) me sale:
Error interno del servidor
El servidor encontró un error interno o mala y no pudo completar su solicitud.
Por favor, póngase en contacto con el administrador del servidor, webmaster y les informará del tiempo se produjo el error, y cualquier cosa que podría haber hecho que pudo haber causado el error.
Más información acerca de este error puede estar disponible en el registro de error del servidor.
Además, un error 500 Internal Server Error fue encontrado al intentar utilizar un ErrorDocument para manejar la petición.
Apache Server en el puerto 80
—
?Que me recomiendan hacer? NECESITO AYUDA YA POR FAVOR!
]]>Hi I need help, a client installed this into her site. Now she only gets 500 errors the whole time. Tried to remove it from from the plugins directory but no luck.
I would have told her to read this support thread and she never would have.
Can someone tell me what to do to remove it?
]]>i try to install in my web and crash and apper:
Internal Server Error
The server encountered an internal error or misconfiguration and was unable to complete your request.
Please contact the server administrator, [email protected] and inform them of the time the error occurred, and anything you might have done that may have caused the error.
More information about this error may be available in the server error log.
Additionally, a 500 Internal Server Error error was encountered while trying to use an ErrorDocument to handle the request.
and now i cant log into panel.
any idea?
]]>My website admin totally broken,got internal error..
i have deleted the files-hide login but its same..please i dont want remake my blog..
После активации выдает ошибку сервера.
Не дает зайти в админку.
Лечится редактированием файла
site_name/.Htaccess
в третьей строке меняем параметр on на off
тем самым отключая плагин, админка заработала, удаляем плагин.
As others describe it. Causes internal server error. Followed installation guide – ether unclear or misleading.
]]>Hello! I’ve upgraded to the new version /3.1/, and my admin page became inaccessible. I’m getting an error and also I see that something is wrong with the status of .htaccess -> “No output”. I need the old version 2.1.
Can somebody gives me a link?
There is only ” internal server Error “
]]>I am using this plugin which is pretty nifty. I did notice however, that there is a slight vulnerability in the URL that can allow someone to bypass it if they get a part of the URL correct.
For example.
https://www.example.com/login is what I have it set to.
if I were to put this:
‘www.example.com/loginnowbecauseisayso’ I would be able to get in. This URL regex schema is not 100%