在CentOS系統中為Laravel應用配置SSL證書,通常需要以下幾個步驟:
獲取SSL證書 首先,你需要獲取一個SSL證書。你可以從證書頒發機構(CA)購買一個證書,或者使用Let’s Encrypt免費獲取一個證書。
安裝Certbot Certbot是一個自動化的工具,用于獲取和配置Let’s Encrypt SSL證書。在CentOS上安裝Certbot,可以使用以下命令:
sudo yum install epel-release
sudo yum install certbot python2-certbot-apache
sudo certbot --apache -d yourdomain.com -d www.yourdomain.com
在提示時,你需要提供電子郵件地址、同意服務條款并設置證書目錄。
/etc/httpd/conf.d/yourdomain.com.conf。確保配置文件中的<VirtualHost>部分包含以下內容:<VirtualHost *:443>
ServerName yourdomain.com
ServerAlias www.yourdomain.com
DocumentRoot /var/www/yourdomain.com/public
SSLEngine on
SSLCertificateFile /etc/letsencrypt/live/yourdomain.com/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/yourdomain.com/privkey.pem
Include /etc/letsencrypt/options-ssl-apache.conf
</VirtualHost>
sudo systemctl restart httpd
.env文件中的APP_URL設置為你的域名,例如:APP_URL=https://yourdomain.com
php artisan make:middleware ForceHttps
在新創建的app/Http/Middleware/ForceHttps.php文件中,修改handle方法:
public function handle($request, Closure $next)
{
if (!$request->secure() && env('APP_ENV') !== 'local') {
return redirect()->secure($request->getRequestUri());
}
return $next($request);
}
然后,在app/Http/Kernel.php文件中將新創建的中間件添加到全局中間件數組中:
protected $middleware = [
// ...
\App\Http\Middleware\ForceHttps::class,
];
現在,你的Laravel應用應該已經成功配置了SSL證書,并且所有流量都會通過HTTPS傳輸。