0

0

Laravel中如何配置HTTPS强制跳转_Laravel开启全站HTTPS访问方法【技巧】

穿越時空

穿越時空

发布时间:2026-01-17 12:01:02

|

964人浏览过

|

来源于php中文网

原创

必须在Web服务器层(Nginx/Apache)配置HTTPS强制跳转,因Laravel中间件无法安全可靠实现全站重定向:明文传输敏感数据、302跳转影响SEO、无法覆盖API/静态资源、不解决混合内容、Secure Cookie判断不可靠;Nginx应配置独立80端口server块return 301,并在Laravel中启用forceScheme、trustedProxies及secure cookie。

laravel中如何配置https强制跳转_laravel开启全站https访问方法【技巧】

必须在 Web 服务器层(Nginx / Apache)配置 HTTPS 强制跳转,Laravel 应用层无法安全、可靠地实现全站 HTTPS 强制重定向。

为什么不能靠 Laravel 中间件做 301 跳转

应用层跳转存在多个致命缺陷:

  • HTTP 请求已进入 PHP 生命周期,敏感数据(如密码、CSRF token)可能已在明文连接中传输
  • 中间件跳转是 302 临时重定向,搜索引擎可能不更新索引;手动写 301 又无法覆盖所有入口(API、静态资源、预检请求)
  • 混合内容(Mixed Content)问题仍会发生:前端编码http:// 链接不会被中间件改写
  • Session/Cookie 的 secure 属性依赖于服务器实际协议,仅靠 $_SERVER['HTTPS'] 判断不可靠(尤其在反向代理后)

Nginx 下强制 HTTPS 的标准配置

在站点 server 块中添加独立的 HTTP server,并使用 return 301(比 rewrite 更高效):

server {
    listen 80;
    server_name example.com www.example.com;
    return 301 https://$server_name$request_uri;
}

server { listen 443 ssl http2; server_name example.com www.example.com;

ssl_certificate /path/to/fullchain.pem;
ssl_certificate_key /path/to/privkey.pem;

# 其他 Laravel 配置(root、index、try_files 等)
root /var/www/laravel/public;
index index.php;

location / {
    try_files $uri $uri/ /index.php?$query_string;
}

location ~ \.php$ {
    fastcgi_pass unix:/var/run/php/php8.2-fpm.sock;
    fastcgi_index index.php;
    fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
    include fastcgi_params;
}

}

Evoker
Evoker

一站式AI创作平台

下载

注意:$server_name 会保留原始 Host,避免多域名时跳转错误;$request_uri 完整保留路径和查询参数。

Laravel 应用内需同步调整的几处关键配置

Web 服务器完成跳转后,Laravel 必须信任代理头并启用安全特性:

  • AppServiceProvider::boot() 中添加:
    if ($this->app->environment('production')) {
        \URL::forceScheme('https');
        \Illuminate\Http\Request::setTrustedProxies(
            ['127.0.0.1', $this->app['request']->server('REMOTE_ADDR')],
            \Illuminate\Http\Request::HEADER_X_FORWARDED_ALL
        );
    }
  • 确保 config/session.php'secure' => env('SESSION_SECURE_COOKIE', true),并在 .env 设置 SESSION_SECURE_COOKIE=true
  • 设置 config/app.php'url' => env('APP_URL', 'https://example.com'),且 .envAPP_URL 必须为 https 开头
  • 生成 URL 时统一用 route()url()asset(),避免硬编码 http://

最易忽略的是:即使 Nginx 已跳转,若未调用 \URL::forceScheme('https') 或未正确设置 trusted_proxies,Laravel 仍可能生成 http:// 链接,导致前端加载失败或 CSRF 失效。代理环境下的协议判断永远以 X-Forwarded-Proto 为准,而不是 $_SERVER['HTTPS']

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2594

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1622

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1509

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1417

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1447

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 7.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号