Secure Your Self Hosted Wordpress

| linux | security | devops |

update 6/12/2024: this post predates letsencrypt, you should just use that instead: https://letsencrypt.org/

Self hosting WordPress rocks. Unsecured websites do not rock. It does not matter how long or complicated your password is if it is being transmitted in plain text over HTTP. Luckily, it is easy to create a Self Signed certificate and use it on your website. Keep in mind that browsers become very unhappy with Self Signed Certificates and tend to yell at the user. So, if you have a lot of traffic and want your users to feel safe purchase an SSL certificate from a real Certificate Authority. In any case, at the very least you should be using a self signed SSL for all of the admin portions of your site. Here’s how to do it on Debian 7.5 running a standard LAMP stack.

  1. Create your self signed Certificate by running the following commands sequentially.
mkdir /etc/apache2/ssl  
openssl req -new -x509 -days 365 -nodes -out /etc/apache2/ssl/wp.pem -keyout /etc/apache2/ssl/wp.key

2.  Create a Virtual Host for your website in /etc/apache2/conf.d/yoursite.conf

<VirtualHost 1.2.3.4:443>
SSLEngine on 
SSLCertificateFile /etc/apache2/ssl/wp.pem 
SSLCertificateKeyFile /etc/apache2/ssl/wp.key 
DocumentRoot /srv/www/yoursite.com/public_html 
  <Directory>
  AllowOverride All 
  order allow,deny 
  Allow from all  
  </Directory>
</VirtualHost>
3.  Enable the SSL module in Apache
sudo a2enmod ssl
4.  Restart apache
sudo service apache2 restart

All set! Now, you can navigate to https://yourwebsite.com, confirm the security exception, and administer and view your WordPress site securely.

Thank you for reading! Share your thoughts with me on bluesky, mastodon, or via email.

Check out some more stuff to read down below.

Most popular posts this month

Recent Favorite Blog Posts

This is a collection of the last 8 posts that I bookmarked.

Articles from blogs I follow around the net

I was inconsiderate but now I’m everywhere

When I was in the music business, there was a record producer who lived in New Jersey, but refused to come into New York City. Anyone that wanted to meet with him had to drive all the way down to his little town. I thought, “What’s his problem? Is he lazy o…

via Derek Sivers blog March 12, 2026

Pluralistic: AI "journalists" prove that media bosses don't give a shit (11 Mar 2026)

Today's links AI "journalists" prove that media bosses don't give a shit: In case there was ever any doubt. Hey look at this: Delights to delectate. Object permanence: Eggflation x excuseflation; Haunted Mansion stretch portraits; "Los…

via Pluralistic: Daily links from Cory Doctorow March 11, 2026

Generative AI vegetarianism

For some spicier takes! Anthony Moser’s “I Am An AI Hater”, Jenny Zhang’s “choosing friction”, Rusty Foster’s “A.I. Isn’t People”, or Ed Zitron’s “The Case Against Generative AI” if you have most of an afternoon to read it. Emily Bender and Alex Hanna’s p…

via Sean Boots March 11, 2026

Generated by openring