187  words
 1  minutes
  🌐 Cloudflare SSL with Nginx (Full Strict) 
  
 🛡️ 1. Generate Cloudflare Origin Certificate
- Go to Cloudflare Dashboard → SSL/TLS→Origin Server
- Click Create Certificate
- Choose:
- ✔️ Let Cloudflare generate a private key and CSR
- ✔️ Key Type: RSA 2048
- ✔️ Validity: 15 years
 
- Copy the certificate and private key
Save the files to your server:
sudo mkdir -p /etc/ssl/cloudflaresudo nano /etc/ssl/cloudflare/cloudflare.crt  # Paste the certificate here
sudo nano /etc/ssl/cloudflare/cloudflare.key  # Paste the private key hereSecure the key and certificate (change permissions)
sudo chmod 600 /etc/ssl/cloudflare/cloudflare.key && chmod 600 /etc/ssl/cloudflare/cloudflare.crt⚙️ 2. Configure Nginx for SSL
Edit your Nginx site configuration:
sudo nano /etc/nginx/sites-enabled/web.confReplace with the following configuration:
server {
    listen 80;
    server_name yourdomain.com www.yourdomain.com;
    return 301 https://$host$request_uri;
}
server {
    listen 443 ssl http2;
    server_name yourdomain.com www.yourdomain.com;
    ssl_certificate /etc/ssl/cloudflare/cloudflare.crt;
    ssl_certificate_key /etc/ssl/cloudflare/cloudflare.key;
    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers HIGH:!aNULL:!MD5;
    ssl_prefer_server_ciphers on;
    location / {
        proxy_pass http://localhost:YOUR_APP_PORT;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto https;
    }
}🔁 Replace:
- yourdomain.com→ your actual domain name
- localhost:YOUR_APP_PORT→ the local port your app is running on (e.g.- localhost:3000)
🚀 3. Restart & Verify
🔎 Test Nginx config:
sudo nginx -t🔁 Restart Nginx:
sudo systemctl restart nginxNOTEYour origin server now uses a Cloudflare-generated certificate with
Full (Strict)SSL enabled and reverse proxy via Nginx securely configured.
 🌐 Cloudflare SSL with Nginx (Full Strict) 
  https://www.itsnooblk.com/posts/cloudflare-ssl-restricted/     
 