A very simple way to quickly password protect your WordPress site with a single password.
This plugin only protects your WordPress generated content. It does not protect images or uploaded files so if you enter and exact URL to in image file it will still be accessible.
- Password protect your WordPress site with a single password.
- Option to allow access to feeds.
- Option to allow administrators access without entering password.
- New 👉 Now you can customize the whole password protected screen including the background, font, logo, color e.t.c.
Please note, this plugin works by setting a cookie to allow access to the site. If you are using a caching plugin or web hosting such as WP Engine that has in-built caching, you will need to configure the caching service to be disabled if the Password Protected cookie is set.
If you would like to translate this plugin you can easily contribute at the Translating WordPress page. The stable plugin needs to be 95% translated for a language file to be available to download/update via WordPress.
To install and configure this plugin…
- Upload or install the plugin through your WordPress admin.
- Activate the plugin via the ‘Plugins’ admin menu.
- Configure the password options in the Password Protected settings.
If you are upgrading manually via FTP rather that through the WordPress automatic upgrade link, please de-activate and re-activate the plugin to ensure the plugin upgrades correctly.
How can I change the WordPress logo to a different image?
How can I enable feeds while the site is password protected?
In the settings, check the ‘Allow Feeds’ checkbox.
Can I prevent administrators having to enter password?
In the settings, check the ‘Allow Administrators’ checkbox.
I cannot preview my changes in the Theme Customizer
You must be an administrator (have the manage_options capability) and in the Password Protected settings, check the ‘Allow Administrators’ checkbox.
How can I log out?
Just add a “password-protected=logout” query to your URL.
I have forgotten the password. How can I disable the plugin?
If you go to your WordPress admin login page
/wp-login.phpand it shows the admin login fields, you should still be able to login and disable the plugin.
If the admin login screen insteads shows the Password Protected field, you will need to access your site via SFTP/SSH and delete the Password Protected plugin folder in the plugins folder
How can I redirect to a different domain name when logging out?
If passing a redirect URL using ‘redirect_to’ when logging out you need you may need to use the allowed domain names filter to allow redirecting to an external domain.
Where can I report bugs and issues?
Please log issues and bugs on the plugin’s GitHub page.
You can also submit suggested enhancements if you like.
How can I contribute?
If you can, please fork the code and submit a pull request via GitHub. If you’re not comfortable using Git, then please just submit it to the issues link above.
How can I translate this plugin?
If you would like to translate this plugin you can easily contribute at the Translating WordPress page. The stable plugin needs to be 90% translated for a language file to be available to download/update via WordPress.
Contributors & Developers
“Password Protected” is open source software. The following people have contributed to this plugin.Contributors
- Improved Settings HTML structure
- Added Note regarding compatibility with login designer within dashboard
- Made compatibility with login designer; Now you can customize the password-protected screen with the customizer using login designer plugin.
- Fix – Author name conflict resolved
wp_no_robotsand replace with
wp_robots_no_robotsfor WordPress 5.7+
- Add a Nocache header to the login page redirect to prevent the browser from caching the redirect page. Props De’Yonte W.
- Remove ‘password-protected’ query from redirects on successful login or logout.
- Check “redirect_to” query var is set in hidden form field. Props Matthias Kittsteiner.
- Add favicon to password protected login page.
password_protected_cookie_namefilter for the cookie name. Props Jose Castaneda.
- Let developers override the capability needed to see the options page via a
password_protected_options_page_capabilityfilter. Props Nicola Peluchetti.
- Don’t use a “testcookie” POST query as it is blocked by Namecheap (and possibly other hosts).
- Fix warnings in W3 validator – script and style “type” attribute not required. Props @dianamurcia.
- Translations now via translate.wordpress.org.
- Updated URL references. Props Garrett Hyder.
password_protected_login_password_titlefilter to allow customizing the “Password” label on the login form. Props Jeremy Herve.
- Fix stray “and” in readme. Props Viktor Szépe.
- Update Portuguese translation. Props Jonathan Hult.
- Update Russian translation. Props Alexey Chumakov.
- Check that
- Restrict REST-API-access only if password protection is active.
- Added viewport meta tag to login page.
- Cookie name is not editable in the admin so display just for reference.
- Use default WordPress text domain for “Remember Me” and “Log In” buttons.
- Change locked Toolbar icon to green.
- Fix REST option and always allow access to REST API for logged in users.
- Fixed PHP error when calculating cookie expiration date.
- Added Toolbar icon to indicate wether password protection is enabled/disabled.
- Option to show “Remember me” checkbox. Props Christian Güdel.
- REST API access disabled if password not entered.
- Admin option to allow REST API access.
- More robust checking of password hashes.
- Update caching notes for WP Engine and W3 Total Cache plugin.
- Tested up to WordPress 4.8
- Declare methods as public or private and use PHP5 constructors.
- Show user’s IP address beside “Allow IP Addresses” admin setting.
- Add CHANGELOG.md and README.md
- Check allowed IP addresses are valid when saving.
- Only redirect to allowed domain names when logging out.
- Split logout functionality into separate function.
- Security fix: Use a more complex password hash for cookie key. Props Marcin Bury, Securitum.
- Added password_protected_logout_link shortcode.
- Load ‘password-protected-login.css’ in theme folder if it exists.
- Added password_protected_stylesheet_file filter to specify alternate stylesheet location.
- Added is_user_logged_in(), login_url(), logout_url() and logout_link() methods.
- Added Basque, Czech, Greek, Lithuanian and Norwegian translations.
- Better handling of login/out redirects when protection is not active on home page.
- Fixed “Allow Users” functionality with is_user_logged_in(). Props PatRaven.
- Added option for allowed IP addresses which can bypass the password protection.
- Added ‘password_protected_is_active’ filter.
- Support for adding “password-protected-login.php” in theme directory.
- Allow filtering of the ‘redirect to’ URL via the ‘password_protected_login_redirect_url’ filter.
- Added ‘password_protected_login_messages’ action to output errors and messages in template.
- Updated translations.
- Use current_time( ‘timestamp’ ) instead of time() to take into account site timezone.
- Check login earlier in the template_redirect action.
- Fix always allow access to robots.txt.
- Added ‘password_protected_login_redirect’ filter.
- Updated translations.
- Fix login template compatibility for WordPress 3.9
- Added ‘password_protected_theme_file’ filter to allow custom login templates.
- Add option to allow logged in users.
- Set login page not to index if privacy setting is on.
- Allow redirection to a different URL when logging out using ‘redirect_to’ query and full URL.
- Language updates by wp-translations.org (Arabic, Dutch, French, Persian, Russian).
- Robots.txt is now always accessible.
- Added support for Uber Login Logo plugin.
- Added note about WP Engine compatibility to readme.txt
- Requires WordPress 3.1+
- Settings now have their own page.
- Fixed an open redirect vulnerability. Props Chris Campbell.
- Add option to allow administrators to use the site without logging in.
- Use DONOTCACHEPAGE to try to prevent some caching issues.
- Added a contextual help tab for WordPress 3.3+.
- Updated login screen styling for WordPress 3.5 compatibility.
- Options are now on the ‘Reading’ settings page in WordPress 3.5
- Added checkbox to allow access to feeds when protection is enabled.
- Prepare for WordPress 3.5 Settings API changes.
- Added ‘password_protected_before_login_form’ and ‘password_protected_after_login_form’ actions.
- Added ‘password_protected_process_login’ filter to make it possible to extend login functionality.
- Now possible to use ‘pre_update_option_password_protected_password’ filter to use password before it is encrypted and saved.
- Ready for translations.
- Show login error messages.
- Escape ‘redirect_to’ attribute. Props A. Alagha.
- Added a “How to log out?” FAQ.
- Only disable feeds when protection is active.
- Encrypt passwords in database.
- First Release. If you spot any bugs or issues please log them here.