SSL Linux
Configure local https on ubuntu
mkcert for simplicity or openssl for more control, and then configure your web server (e.g., Apache) to use the generated certificates. The recommended method is to install and use mkcert, which generates a trusted, local Certificate Authority (CA) to create self-signed certificates for localhost or custom hostnames without browser warnings. Alternatively, you can generate a self-signed certificate using openssl, which requires more manual steps to create the key, certificate, and to trust it in your browser.
mkcert (Recommended)- Install
mkcert: Install the tool to manage local certificate authorities and certificates.sudo apt install mkcert
- Install the local CA: Run
mkcertto install a local CA that your system will trust.mkcert -install
- Create a certificate: Generate a certificate and key for your local site (e.g.,
localhost) or domain. Point to note here in case of domain, ip address should be mapped to it before this command.mkcert localhost 127.0.0.1sudo mkcert drupalwithdata.offline.com
Configure your server: Configure your specific application or web server to use the generated localhost.pem (certificate) and localhost-key.pem (key) files.
- Install
openssl: Ensureopensslis installed. It is usually pre-installed on Ubuntu. - Generate a private key and a certificate signing request (CSR):
openssl req -new -newkey rsa:2048 -nodes -keyout localhost.key -out localhost.csr
- Generate the self-signed certificate: Use the CSR and private key to create the certificate.
openssl x509 -req -days 365 -in localhost.csr -signkey localhost.key -out localhost.crt
- Configure your web server:
- For Apache:
- Enable the SSL module:
sudo a2enmod ssl. - Configure your site's virtual host to point to your certificate (
localhost.crt) and private key (localhost.key) files. - Restart Apache:
sudo systemctl restart apache2.
- Enable the SSL module:
- For other servers: Configure your server's settings to use the
.crtand.keyfiles.
- For Apache:
- Trust the certificate:
- This is an optional but recommended step to avoid browser warnings.
- Install certificate utilities:
sudo apt-get install libnss3-tools. - Import and trust the certificate into the browser's database (using
pk12utilfor Firefox orcertutilfor other applications).
- After generating the certificates and configuring your server, you may still see a browser warning because the certificate is "self-signed" and not issued by a public Certificate Authority.
- You will need to accept the security risk to proceed to your local serve
install OpenSSL locally on Ubuntu
compile and install it from source by first installing build tools, then downloading and extracting the OpenSSL source code, and finally running the config, make, and make install commands with the appropriate prefix and flags. For the simplest local installation, download the source, change to the directory, and use ./config --prefix=/openssl --openssldir=/openssl, followed by make and make install, then update your ~/.bash_profile with the correct PATH and LD_LIBRARY_PATH.
~/openssl, so it doesn't interfere with the system-installed version.# Install build tools
sudo apt update
sudo apt install build-essential zlib1g-dev
# Create a working directory and download OpenSSL source
cd /usr/local/src/
wget https://www.openssl.org/source/openssl-1.1.1k.tar.gz
tar -xf openssl-1.1.1k.tar.gz
cd openssl-1.1.1k
# Configure and build (using --prefix to specify local install)
./config --prefix=~/openssl --openssldir=~/openssl
make
# Install to the local directory
make install
- Edit the bash profile:
bash
-
nano ~/.bash_profile - Add the following lines at the end of the file (adjusting
usernameif necessary):bash -
export PATH=$HOME/openssl/bin:$PATH export LD_LIBRARY_PATH=$HOME/openssl/lib:$LD_LIBRARY_PATH export LDFLAGS="-L $HOME/openssl/lib -Wl,-rpath,$HOME/openssl/lib" - Save and close the file, then reload your profile:
bash
source ~/.bash_profile
- Check the version to ensure you are using the new installation:
bash
-
This should output the version you installed (e.g.,openssl versionOpenSSL 1.1.1k 25 Mar 2025).
Verify the path to confirm it's the local one:bash
which openssl
This should point to ~/openssl/bin/openssl