How to Restore a Hacked WordPress Site

It’s a bit of a nightmare when your website gets hacked.

Most security specialists will charge you a premium to restore your site and they won’t tell you what’s involved in the process.  

Shhhhh – it’s a secret! 🤐

Not me!

I’d like to share my 22-step plan on how to restore a hacked WordPress site so that you can see exactly what I do and how much effort it takes.

You can do this yourself if you have the time and skills.

Restoring A Hacked WordPress Site – Step Process

  1. Zip up the entire remote site files and download them to local
  2. Wipe the remote root folder (everything goes)
  3. Change FTP, cPanel, email account and MySQL passwords
  4. Unzip local site and scan for any malware using a good quality antivirus software, e.g. Norton.
  5. Search all the local site file contents for terms such as preg_replace(“/.*/e” and base64_decode
    Note: there are legitimate uses for Base64 decoding.  What you are looking for is a large number of hex or escape strings
    i.e. “\x65\x76\x61\x6c\x20\x28\x20\x67\x7a\x69\x6e\x66\x6c\x61\x74\x65”
  6. Perform an operating system (Windows/MacOs/Limux) search across the local folder for timthumb.php – if found – you need to scrap the plugin and find an alternative – read why timthumb.php is evil !!
  7. Check that your .htaccess file hasn’t been compromised and check that there are no other .htaccess files in any other folder (windows search)
  8. Create a new separate root folder and unzip the latest WordPress version there
  9. Copy your wp-config.php from the old site over to the new folder
  10. Change your DB_PASS and your secret keys
  11. Upload new clean bare WP to the remote site
  12. Login to WordPress and immediately change all user passwords – try to use a random password generator like https://www.vpnmentor.com/tools/secure-password-generator/ and bump the characters up to 12 or 16
  13. Install the “WordFence” firewall plugin
  14. If you don’t want to install a full firewall plugin (what are you nuts? Your site just got hacked!) at the very least install the “Limit Login Attempts Reloaded” plugin and set it to 3 attempts
  15. Create a new administrator user. Hint: don’t call it Admin, Sys, System, Administrator, Operator, WordPress or anything like that
  16. Delete the old administrator users making sure the posts/pages are inherited by the new administrator user created in the previous step
  17. Now you have a working and secured core WP installation
  18. Reinstall all the plugins from the Admin Dashboard and reactivate them if WP has already had them deactivated. The settings should be already stored in the DB
  19. Upload / FTP your theme to the live server and reactivate the theme. The theme settings should be picked up from the DB but I’ve had instances where you have to set up menus again – bad theme!
  20. Last to upload / FTP is your wp-content/uploads (and any other non-WP folders in there after checking they are OK and contain only the correct media)
    Note: this is a favourite place for hackers to store their .php or .cgi scripts sometimes named “cache”
  21. I recommend using Xcloner as a backup tool and setting up a cPanel crontab job to perform your backups. Either FTP them to another site or purchase an Amazon S3 storage bin – it’s ultra-cheap

Depending on how familiar you are with WordPress and hosting control panels and how many plugins and uploads a site has, this process is very time-consuming.  Restoration time depends on how many files make up your website as they all need to get checked.

I provide a hacked WordPress website restoration service if you don’t have the required technical skills or time to do it.

And once your site is up and running again you may want to start putting into place some extra web security policies and processes.

Has your WordPress site been hacked recently?  Tell us your story.

Was this article helpful?
YesNo

Get Your Free Security Fundamentals eBook

Enhance your website security with this free, quick and easy to implement guide.

Keep In Touch

Wil

Wil is a dad, WordPress consultant, WordPress developer, business coach and mentor. He co-organizes the WordPress Sydney meetup group and has been on the organising committee for WordCamp Sydney since 2014. He speaks at many special events and contributes to the WordPress open source project. His likes are chillies, craft beer and electrogravitics.

5 thoughts on “How to Restore a Hacked WordPress Site”

  1. Will, great read. May have to ask your advise in come consulting. I’m very comfortable with WP, but I’m an operations guys, infrastructure etc. WP design, form and function I do not feel is my strong point.

    Great Article.
    DVR

Comments are closed.