Is your WordPress secure?
Local Risks that matter. Are you mitigating them or avoiding these?
- Do you have an antivirus (up-to-date)? (Kaspersky, Avast, Super Anti-Spyware, MalwareBytes.org or any other which does a great job)
- Are you doing a weekly scanning (full-scan) on the computer that you use for your work?
- If you use a public computer, do you trust them?
- There is no point in having a great website security if your computer is infected by a keylogger.
- Are you leaving your cPanel session alive without logging out?
- Are you using a secure enough password on your cPanel?
- FTP software that you are using is secure enough? (For instance: WS_FTP has a security vulnerability) Read more at https://www.cvedetails.com/vulnerability-list/vendor_id-193/product_id-336/Ipswitch-Ws-Ftp-Server.html
- Is your WiFi protected? Are you using WPA2? If not, then I recommend.
- You like to work from Coffee Shop or Starbucks? Maybe you don’t want to login to your bank account, wordpress site, cPanel or anything that is sensitive and is of value to you.
- Maybe you can try using VPN software?
- I recommend to use work computer or bank account details on a computer which is only used for “safe-browsing” purposes. Do not mix torrent or the websites which are really malware prone with your work.
- In short, make your local environment is safe and secure. It just takes awareness and following certain guidelines mentioned above.
Is your hosting secure?
- Shared hosting: Usually unsafe if you are a reputed business and also it becomes easier for hackers to see your data when they hack into someone else’s account.
- How credible is your hosting company? Maybe you can do some search on Google, ask questions, and do some research. WARNING: Avoid FAKE warning sites.
- Good web hosting = Pricing is gonna be a bit expensive. Bad Web Hosting = Very cheap and very vulnerable.
Is your WordPress Security up-to-date
- Are you updating your WordPress timely?
- Maybe you can turn on auto-updates on your hosting control panel?
- Are you using WordPress hosting services?
- Are you using backup services and also some secure server settings on your cPanel?
- Maybe you want to look at https://wpengine.com/plans/ (Managed Hosting and Security plans) for your WordPress. [ Optional ].
Changing configuration of your WordPress
- Change the settings of your WordPress because WordPress is open-source and black-hat hackers may be aware of certain naming conventions and try to gain access or try hacking using those default values. Change is better 😉
- Modify the table prefix (change wp_ to something else).
- Change the “admin” username. Change it so something else which is not easy to guess by a human or brute force tool.
- Set a secure password. (Do not use family name, dictionary name, 123456 sequence or 123 in the end of the password).
- Security keys in WordPress to add a layer of security.
- I see some wordpress sites show the username as author / display name in articles or blog posts. In such case, you changing “admin” default username to something else is total waste. Doesn’t make sense.
WordPress Secure Installation
- Create a new database with “not so easy to guess” database name. (This is to change the table prefix of default wordpress which is wp_)
- Go to MySQL in cPanel and create new database. Create the database name something like, “r238ab991” this is hard to guess.
- Next step is to create a strong username and strong password (I know it’s hard, but you can try).
- Use usernames like ew8292lkn320 and password as (maybe you can use password generators provided in your hosting. But, make sure they are more than 10 characters with better password rules). Look into the password strength meter as well if your hosting as one (But, beware of buggy ones. I can show 100/100 by using less than 6 characters too J).
- Make sure you give “All Privileges” to the database user you created.
- Download the latest update wordpress files from http://wordpress.org/ website.
- Open wp-config-sample.php file with text editor once you extract the compressed files or archive.
- Replace the values with your database name, database user and database password.
- In the same file wp-config-sample.php, you will find a place to add secure keys. Generate the keys and use them. Your WordPress API to create these salt / keys.
- Also, change the table prefix from wp_ to something else.
- Change the wp-config-sample.php file to wp-config.php
- Connect to FTP using FileZilla and transfer all the wordpress files to your server.
- Once uploaded, go to your website in the web browser.
[ You will see wp-admin/install.php Choose your language and continue ]
- In the username “DO NOT USE admin as USERNAME”. Choose something obscure. For instance: ce897esc
- Choose the password which is stronger. Longer the password, better the password. Maybe you can use http://strongpasswordgenerator.com/ to generate secure password with better entropy.
- There is a setting called “Allow your website to be indexed by search engine”. It is checked by default. You can uncheck it till you create a full-fledged website with all pages in place.
- Once the installation is done, make sure you change your Display Name. You don’t want your obscure username to be displayed as author under every blog post. That’s a hint for black-hat hacker to use the same username in wp-admin login form. To change this, go to Users → Your Profile and go to “Nickname” field. Change it to something else. It can be your name or full name or anything else. Then choose the Nickname as “Display name publicly as”.
Plugins to be installed on WordPress for better security
- Limit login attempts
- Clef secure passwordless login
- All in one WP Security and Firewall
- Limit IP addresses to login (whitelisting IP addresses)
- Hide the login page
- CAPTCHA on the login page (reCAPTCHA)
- Tw0-factor authentication
- .htpasswd (You need to enter this password and only then the server will authenticate you to show the login page. Extra layer for better security).
- Check the plugin’s last updated date on WordPress.org plugins page.
- Also, look into the reviews and star rating for the specific plugin
- Add Google Authenticator on your Smartphone and then install Google Authenticator plugin on your WordPress site.
- Some other easier plugins: Due 2 Factor Authentication and UNLOQ.io Authentication
- Create .htaccess and .htpasswd file to protect wp-login.php
- Also, password protect /wp-admin directory through cPanel
- Login errors that give hint to the black-hat hackers about valid usernames and invalid ones. (Wordfence plugin has this option under “Options” to avoid this).
- Turn on “Automatic updates” for plugins
WP Updates Settings (To update the plugins always)
- Remove /readme.html from the File Manager. Also, remove the license.txt file from the web server.
- Change the permissions for file and folders for User, Group and World. (Read Write Execute permissions). Never give 777 to directories.
- Move wp-config.php file from public_html or wwwroot folder to one level higher folder. This way we make sure it is bit more secure as hackers cannot try to access it whatsoever unless they break into the cPanel or Control Panel of hosting provider or they get access to FTP.
- Create a robots.txt file to secure your folders or sensitive files being indexed by search engine spiders
Blocking IP’s (Malicious Activity)
- Block specific IP address
- Block entire network
- Block narrow range of a network
Plugin to avoid Brute-Force attack
- Jetpack by WordPress.com
- Turn on the Brute Force Avoiding feature
- Also, Jetpack provides whitelist IP addresses (Just in case if you try to do invalid login attempts).
- Wordfence also has brute-force protection (Not sure at this point of time if that feature is in commercial version or free version).
Be aware of themes and plugins which are vulnerable
- Never use thepiratebay to download wordpress plugins
- BIG NO to thewarriorforum.com
Reliable places to go to buy themes
- WordPress.org (All are free)
- Take backup [ Regular ]
- Full backups
- Partial backups
- Run scheduled full scan on your local environment
- Use WiFi with WPA encryption
- Use secure FTP to transfer files from your computer to server
- Maintain audit logs on your hosting environment
- Check your .htaccess files to see if it was modified by hacker to have redirect
- Check your plugins
- Check your users [ Maybe it was some other user who has admin access. Is it only you who is admin? If it’s only you, was the password leaked or cracked? ]
- Use scanners like WP Scan http://wpscan.org/ and http://sucuri.net/
- Use the GOTMLS scan and run the scanner → Get off the maliciously loaded scripts
- Protect your privacy of whois information [ You don’t want hackers to know the administrator email address and hack it in order to compromise your hosting account ].
- Something fishy? Change all your passwords. WordPress, hosting account, .htaccess .htpasswd, salt keys in wp-config.php, Google Authenticator / 2 factor authentication etc.
- Use WP Security Audit Log to do automatic audits for your WordPress website.
- Use Wordfence to avoid brute-force attacks, live traffic analysis, use it for blocking IPs or network for specific time and more features.
- You can also use https://hackertarget.com/wordpress-security-scan/ to scan your wordpress website.
- Block Bad Queries, Blackhole for bad bots, WPBruiser
Disabling author pages (http://example.com/?author=1 or 2 or 3...N)
Add the following piece of code under the theme or child theme,
header("HTTP/1.1 301 Moved Permanently");
This has to be in authors.php file. Also, you can use Yoast plugin, but this edit in authors.php is better in my view.
Setting up the HTTP headers using HTTP headers plugin
Plugin URL: https://wordpress.org/plugins/http-headers/