在CentOS上為Laravel項目配置SSL證書,通常需要以下幾個步驟:
以Let’s Encrypt為例,你可以使用Certbot來獲取免費的SSL證書。在CentOS上安裝Certbot:
sudo yum install epel-release
sudo yum install certbot python2-certbot-apache
yourdomain.com
替換為你的實際域名:sudo certbot --apache -d yourdomain.com -d www.yourdomain.com
按照提示操作,Certbot會自動配置Apache服務器并啟用HTTPS。
.env
文件中設置APP_URL
變量,以確保所有鏈接都是安全的:APP_URL=https://yourdomain.com
此外,你還可以使用Laravel的內置輔助函數secure_link()
來生成安全的URL。
public
目錄下。然后,編輯Nginx配置文件(通常位于/etc/nginx/conf.d/yourdomain.com.conf
),添加以下內容:server {
listen 80;
server_name yourdomain.com www.yourdomain.com;
return 301 https://$host$request_uri;
}
server {
listen 443 ssl;
server_name yourdomain.com www.yourdomain.com;
ssl_certificate /path/to/your/fullchain.pem;
ssl_certificate_key /path/to/your/privkey.pem;
ssl_protocols TLSv1.2 TLSv1.3;
ssl_ciphers 'ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384';
ssl_prefer_server_ciphers on;
root /path/to/your/laravel/public;
index index.php index.html index.htm;
location /
{
try_files $uri $uri/ /index.php?$query_string;
}
# 其他配置...
}
將/path/to/your/
替換為實際的證書文件路徑和Laravel項目路徑。保存更改后,重啟Nginx服務:
sudo systemctl restart nginx
現在,你的Laravel項目應該已經成功配置了SSL證書,并可以通過HTTPS訪問。