Really Simple SSL automatically detects your settings and configures your website to run over https.
To keep it lightweight, the options are kept to a minimum. The entire site will move to SSL.
Three simple steps for setup:
- Get an SSL certificate (can’t do that for you, sorry).
- Activate this plugin
- Enable SSL with one click
Always backup before you go! If you do not have a sound backup policy, start having one! For a snapshot, install duplicator.
Really Simple SSL is on GitHub as well!
Love Really Simple SSL?
Hopefully this plugin save you some hours of work. If you want to support the continuing development of this plugin, you might consider buying the premium, which includes
some cool features.
- The mixed content scan, which shows you what you have to do if you don’t have the green lock yet
- The option to enable HTTP Strict Transport Security
- The option to configure your site for the HSTS preload list
- Mixed Content Fixer for the back-end
- More detailed feedback on the configuration page.
- Certificate expiration check: get an email when your SSL certificate is about to expire.
- Premium support
What does the plugin actually do
- The plugin handles most issues that WordPress has with ssl, like the much discussed loadbalancer issue, or when there are no server variables set at all.
- The site url and home url are changed to https.
- Your insecure content is fixed by replacing all http:// urls with https://, except hyperlinks to other domains. Dynamically, so no database changes are made (except for the siteurl and homeurl).
Like to have this plugin in your language?
Translations can be added very easily here. If you do, I can get you added as translation editor to approve the translations.
Imagens de tela
To install this plugin:
- Make a backup!
- Install your SSL certificate
- Download the plugin
- Upload the plugin to the wp-content/plugins directory,
- Go to “plugins” in your WordPress admin, then click activate.
- You will now see a notice asking you to enable SSL. Click it and log in again.
- Knowledge base
For more detailed explanations and documentation on redirect loops, deactivating, mixed content, errors, and so on, please search the documentation
- Does the mixed content fixer make my site slower?
On a site where the source consists of about 60.000 characters, the delay caused by the mixed content fixer is about 0.00188 seconds. If this is too much for you, fix the mixed content manually and deactivate it in the settings.
- Uninstalling Really Simple SSL
The plugin checks your certificate before enabling, but if, for example, you migrated the site to a non-ssl environment, you might get locked out of the back-end.
If you can’t deactivate, do not just remove the plugin folder to uninstall! Follow these instructions.
- Mixed content issues
Most mixed content issues are caused by urls in css or js files.
For detailed instructions on how to find mixed content read this article.
- Redirect loop issues
If you are experiencing redirect loops on your site, try these instructions.
Amazing piece of software. With a click of a button all http references turn into https. Awesome.
Thanks Rogier for your very helpful response.
The best of a product is not the product itself : it is the support that goes with it.
But here, the product is terrific AND the support is amazing.
I had a big problem of SSL activation, due to my host (and a mystery that hasn’t been solved yet), and Rogier were so implicated in helping me, he tried all he could to avoid me having troubles and gave me the best advices.
When the SSL has been endly activated, he installed it himself, as I was freaked out to do it myself and do something wrong.
You can definetely judge a seller on his way of handling anxious people like me 😀
He has been so patient, reactive and professionnal. If I could give a 6th star, I would.
Just bought a SSL certificate for one of my TransIP shared hosting clients, and it took 1.5 hours to fiddle with all kinds of settings and still didn’t have it working. Then used this plugin, and BAM! Had it all working withing 5 minutes! Highly recommended plugin!
Just installed LE certificate and used this to work alongside cloudflare.
Sometimes I have to disable insecure content warning, & reload the page to get it working. But then click a button it just works, which is how I love it.
Contribuidores e desenvolvedores
“Really Simple SSL” é um software com código aberto. As seguintes pessoas contribuíram para este plugin.Contribuidores
Interessado no desenvolvimento?
Registro de alterações
- Removed curl in favor of wp_remote_get
- Fastest cache compatibility fix
- Multisite tweaks
- Removed automatic insertion of .htaccess redirects. The .htaccess redirects work fine for most people, but can cause issues in some edge cases.
- Added option to explicitly insert .htaccess redirect
- Added safe mode constant RSSSL_SAFE_MODE to enable activating in a minimized way
- Fix: RLRSSSL_DO_NOT_EDIT_HTACCESS constant did not override setting correctly when setting was used before.
- Dropped cache flushing on activation, as this does not always work as expected
- Tweak: changes testurl to the function test_url()
- version nr fix
- Reverted some changes to 2.4.3, as it was causing issues for some users.
fix: Adjusted selection order of .htaccess rules, preventing redirect loops
- Changed .htaccess redirects to use only one condition
- removed file_get_contents function from class_url.php, as in some cases this causes issues.
- Added help tooltips
- Fix: typos in explanations
- Added detected server to debug Log
- Added test folder for CloudFlare
- Added htaccess redirect to use all available server vars for checking SSL.
- Tweak: Improved support for cloudflare
- Tweak: Added support for Cloudfront, thanks to Sharif Alexandre
- Fix: Prevent writing of empty .htaccess redirect
- Tweak: Added option for 301 internal wp redirect
- Tweak: Improved NGINX support
- Tweak: Added support for when only the $_ENV[HTTPS] variable is present
- Fix: Mixed content fixing of escaped URLS
- Removed banner in admin
- Tweak: Added reload over https link for when SSL was not detected
- Fixed: After reloading page when the .htaccess message shows, .htaccess is now rewritten.
- Tweak: Removed Yoast notices
- Tested for WP 4.7
- Fixed: bug where network options were not removed properly on deactivation
- Tweak: Changed mixed content marker to variation without quotes, to prevent issues with scripting etc.
- Tweak: improved HSTS check
- Fixed: added a version check on wp_get_sites / get_sites to get rid of deprecated function notice, and keep backward compatibility.
- Fixed: A bug in multisite where plugin_url returned a malformed url in case of main site containing a trailing slash, and subsite not. Thanks to @gahapati for reporting this bug.
- Tweak: Added button to settings page to enable SSL, for cases where another plugin is blocking admin notices.
- Tweak: Rebuilt the mixed content fixer, for better compatibility
- Tweak: Improved the mixed content marker on the front-end, so it’s less noticeable, and won’t get removed by minification code.
- Fixed: Clearing of WP Rocket cache after SSL activation causing an error
- Fixed: Clearing of W3TC after SSL activation did not function properly
- Re-inserted Jetpack fix.
- Requires at least changed back to 4.2, as the function that this was meant for didn’t make it in current release yet.
- Improved request method in url class
- Added check if .htaccess actually exists in htaccess_contains_redirect_rules()
- Made activation message more clear.
- Tested for 4.6
- Tweak: changed check for htaccess redirect from checking the RSSSL comments to checking the redirect rule itself
- Fix: htaccess not writable message not shown anymore when SSL not yet enabled
- Tweak: extended mixed content fixer to cover actions in forms, as those should also be http in case of external urls.
- Tweak: added safe domain list for domains that get found but are no threat.
- Tweak: added filter for get_admin_url in multisite situations, where WP always returns an https url, although the site might not be on SSL
- Tweak: htaccess files and wpconfig are rewritten when the settings page is loaded
- Fix: removed internal WordPress redirect as it causes issues for some users.
- Tweak: improved url request method
- Tweak: Fallback redirect changed into internal wp redirect, which is faster
- Tweak: When no .htaccess rules are detected, redirect option is enabled automatically
- Tweak: Url request falls back to file_get_contents when curl does not give a result
- Updated screenshots
- Fixed: missing priority in template_include hook caused not activating mixed content fixer in some themes
- Tweak: load css stylesheet only on options page and before enabling ssl
- Tweak: mixed content fixer triggered by is_ssl(), which prevents fixing content on http.
- Start detection and configuration only for users with “manage_options” capability
- Fixed bug in force-deactivate script
- Changed SSL detection so test page is only needed when not currently on SSL.
- Some minor bug fixes.
- Removed “activate ssl” option when no ssl is detected.
- Optimized emptying of cache
- Fixed some bugs in deactivation and activation of multisite
- Given more control over activation process by explicity asking to enable SSL.
- Added a notice if .htaccess is not writable
Fixed a bug in SSL detection
Changed followlocation in curl to an alternative method, as this gives issues when safemode or open_basedir is enabled.
Added dismissable message when redirects cannot be inserted in the .htaccess
Fixed bug in logging of curl detection
Security fixes in ssl-test-page.php
Bugfix with of insecure content fixer.
Added a check if the mixed content fixer is functioning on the front end
Fixed a bug where multisite per_site_activation variable wasn’t stored networkwide
Added clearing of wp_rocket cache thans to Greg for suggesting this
Added filter so you can remove the really simple ssl comment
Fixed a bug in the output buffer usage, which resolves several issues.
Added code so JetPack will run smoothly on SSL as well, thanks to Konstantin for suggesting this
- To prevent lockouts, it is no longer possible to activate plugin when wp-config.php is not writable. In case of loadbalancers, activating ssl without adding the necessary fix in the wp-config would cause a redirect loop which would lock you out of the admin.
- Moved redirect above the wordpress rewrite rules in the htaccess.
Brand new content fixer, which fixes all links on in the source of your website.
- Roll back of mixed content fixer.
Improved the mixed content fixer. Faster and more effective.
Edited the wpconfig define check to prevent warnings when none are needed.
- Extended detection of homeurl and siteurl constants in wp-config.php with regex to allow for spaces in code.
- Changed text domain to make this plugin language packs ready
- Added 404 detection to ssl detection function, so subdomains can get checked properly on subdomain multisite installs
Added slash in redirect rule
- Added multisite support for the missing https server variable issue
- Improved curl connection script
- Added French translation thanks to Cedric
- Small bug fixes
- Added per site activation for multisite, but excluded this option for subfolder installs.
- Added script to easily deactivate the plugin when you are locked out of the wordpress admin.
- Added support for a situation where no server variables are given which can indicate ssl, which can cause WordPress to generate errors and redirect loops.
- Removed warning on Woocommerce force ssl after checkout, as only unforce ssl seems to be causing problems
- Added Russian translation, thanks to xsascha
- Improved redirect rules in the .htaccess
- Added option te disable the plugin from editing the .htaccess in the settings
- Fixed a bug where multisite would not deactivate correctly
- Fixed a bug where insecure content scan would not scan custom post types
- Made woocommerce warning dismissable, as it does not seem to cause issues
- Fixed a bug caused by WP native plugin_dir_url() returning relative path, resulting in no ssl messages
- Fixed a bug where example .htaccess rewrite rules weren’t generated correctly
- Added woocommerce to the plugin conflicts handler, as some settings conflict with this plugin, and are superfluous when you force your site to ssl anyway.
- Excluded transients from mixed content scan results
- Fixed a bug where script would fail because curl function was not installed.
- Added debug messages
- Improved FAQ, removed typos
- Replaced screenshots
- Improved user interface with tabs
- Changed function to test ssl test page from file_get_contents to curl, as this improves response time, which might prevent “no ssl messages”
- Extended the mixed content fixer to replace src=”http:// links, as these should always be https on an ssl site.
- Added an errormessage in case of force rewrite titles in Yoast SEO plugin is used, as this prevents the plugin from fixing mixed content
- Added support for loadbalancer and is_ssl() returning false: in that case a wp-config fix is needed.
- Improved performance
- Added debuggin option, so a trace log can be viewed
- Fixed a bug where the rlrsssl_replace_url_args filter was not applied correctly.
- Fixed an issue where in some configurations the replace url filter did not fire
- Added the force SSL option, in cases where SSL could not be detected for some reason.
- Added a test to check if the proposed .htaccess rules will work in the current environment.
- Readded HSTS to the htaccess rules, but now as an option. Adding this should be done only when you are sure you do not want to revert back to http.
- Improved instructions regarding deinstalling when locked out of back-end
- Removed HSTS headers, because it is difficult to roll back.
- Added the possibility to prevent htaccess from being edited, in case of redirect loop.
- Refined SSL detection
- Bugfix on deactivation of plugin
- Fixed an SSL detection issue which could lead to redirect loop
- Improved redirect rules for .htaccess
- Now plugin only changes .htaccess when one of three preprogrammed ssl types was recognized.
- Simplified filter use to add your own urls to replace, see f.a.q.
- Fixed bug where number of options with mixed content was not displayed correctly
- limited the number of files, posts and options that can be show at once in the mixed content scan.
- Added version control to the .htaccess rules, so the .htaccess gets updated as well.
- Added detection of loadbalancer and cdn so .htaccess rules can be adapted accordingly. Fixes some redirect loop issues.
- Added the possibility to disable the auto replace of insecure links
- Added a scan to scan the website for insecure links
- Added detection of in wp-config.php defined siteurl and homeurl, which could prevent from successfull url change.
- Dropped the force ssl option (used when not ssl detected)
- Thanks to Peter Tak, PTA security for mentioning the owasp security best practice https://www.owasp.org/index.php/HTTP_Strict_Transport_Security in .htaccess,
- Added 301 redirect to .htaccess for seo purposes
- Fixed some typos in readme
- added screenshots
- fixed a bug where on deactivation the https wasn’t removed from siturl and homeurl
- Added SSL detection by opening a page in the plugin directory over https
- Added https redirection in .htaccess, when possible
- Added warnings and messages to improve user experience
- Added automatic change of siteurl and homeurl to https, to make backend ssl proof.
- Added caching flush support for WP fastest cache, Zen Cache and W3TC
- Fixed bug where siteurl was used as url to fix instead of homeurl
- Fixed issue where url was not replaced on front end, when used url in content is different from home url (e.g. http://www.domain.com as homeurl and http://domain.com in content)
- Added filter so you can add cdn urls to the replacement script
- Added googleapis.com/ajax cdn to standard replacement script, as it is often used without https.
- Improved installation instructions