0

0

解决 Laravel 项目在共享主机上链接失效的 404 错误

花韻仙語

花韻仙語

发布时间:2025-07-02 21:26:28

|

696人浏览过

|

来源于php中文网

原创

解决 laravel 项目在共享主机上链接失效的 404 错误

本教程旨在解决 Laravel 项目部署到共享主机(如 000webhost)后,内部链接出现 404 错误的问题。核心解决方案是通过在网站根目录配置 .htaccess 文件,确保服务器正确重写 URL 并将所有请求导向 Laravel 的 index.php 前端控制器,从而恢复路由功能。

理解 Laravel 路由与共享主机环境的挑战

Laravel 框架采用“前端控制器”模式,这意味着所有 HTTP 请求都应通过位于项目 public 目录下的 index.php 文件进行处理。index.php 负责加载框架核心,解析请求的 URL,并将其路由到相应的控制器或闭包函数。在本地开发环境中,通常由 PHP 内置服务器、Nginx 或 Apache 配置来确保所有请求都正确地重定向到 index.php。

然而,当 Laravel 项目部署到某些共享主机环境时,服务器的默认配置可能无法识别这种重写规则,导致除了根 URL (/) 之外的所有内部链接都返回 404 错误。这是因为服务器在文件系统中找不到与请求 URL 直接对应的物理文件或目录,而没有将请求转发给 index.php 进行动态处理。

解决方案:配置 .htaccess 文件

解决此问题的关键在于为 Apache 服务器配置正确的 URL 重写规则。这通常通过在网站的文档根目录(在 000webhost 这样的主机上通常是 public_html 目录)中创建一个或修改现有的 .htaccess 文件来实现。此文件将指示 Apache 如何处理传入的请求,确保它们被 Laravel 的 index.php 文件捕获。

以下是适用于 Laravel 项目的 .htaccess 文件内容:

Vondy
Vondy

下一代AI应用平台,汇集了一流的工具/应用程序

下载
<IfModule mod_rewrite.c>
<IfModule mod_negotiation.c>
    Options -MultiViews
</IfModule>

RewriteEngine On

# 移除尾部斜杠,如果不是目录的话
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)/$ /$1 [L,R=301]

# 处理前端控制器:将所有非文件/非目录请求重写到 index.php
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^ index.php [L]

# 处理授权头部
RewriteCond %{HTTP:Authorization} .
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
</IfModule>

.htaccess 文件内容解析:

  1. <IfModule mod_rewrite.c>: 这是一个条件块,确保只有在 Apache 服务器启用了 mod_rewrite 模块时,其中的规则才会被应用。这是 URL 重写功能的基础。
  2. <IfModule mod_negotiation.c> Options -MultiViews </IfModule>: MultiViews 是 Apache 的一个功能,它允许服务器尝试自动查找与请求文件名匹配的文件(例如,请求 example 但存在 example.php 或 example.html)。禁用此选项可以防止与 Laravel 的路由系统发生冲突,确保请求完全由 .htaccess 规则控制。
  3. RewriteEngine On: 显式开启 Apache 的 URL 重写引擎。
  4. RewriteCond %{REQUEST_FILENAME} !-d 和 *`RewriteRule ^(.)/$ /$1 [L,R=301]`**:
    • RewriteCond %{REQUEST_FILENAME} !-d: 这是一个条件,表示只有当请求的 URI 不是一个实际存在的目录时,才应用后续的规则。
    • RewriteRule ^(.*)/$ /$1 [L,R=301]: 这条规则会移除 URL 末尾多余的斜杠(例如 example.com/about/ 会被重定向到 example.com/about)。[L] 表示这是最后一条规则,[R=301] 表示执行一个永久重定向。
  5. RewriteCond %{REQUEST_FILENAME} !-dRewriteCond %{REQUEST_FILENAME} !-fRewriteRule ^ index.php [L]:
    • RewriteCond %{REQUEST_FILENAME} !-d: 条件,如果请求的 URI 不是一个实际存在的目录。
    • RewriteCond %{REQUEST_FILENAME} !-f: 条件,如果请求的 URI 不是一个实际存在的文件。
    • RewriteRule ^ index.php [L]: 这是 Laravel 路由的核心。如果上述两个条件都满足(即请求的 URI 既不是文件也不是目录),则将所有请求重写到 index.php。^ 匹配任何请求,[L] 表示这是最后一条重写规则。
  6. RewriteCond %{HTTP:Authorization} . 和 *`RewriteRule . - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]`**:
    • 这两行规则确保 HTTP 请求中的 Authorization 头部信息能够被正确地传递给 PHP 应用程序。这对于处理 API 请求中的认证令牌(如 Bearer Token)至关重要。

实施步骤

  1. 准备 Laravel 项目文件: 通常,为了在共享主机上部署 Laravel,你需要将 Laravel 项目 public 目录下的所有内容(包括 index.php、.htaccess 文件、CSS/JS/图片等静态资源)直接上传到主机的文档根目录(例如 public_html)。项目的其余部分(app、bootstrap、vendor 等)应该上传到 public_html 的上一级目录或同级目录,以保证其安全性和私密性。
  2. 创建或修改 .htaccess 文件:
    • 在你的本地 Laravel 项目的 public 目录下,通常已经有一个 .htaccess 文件。确认其内容与上述示例一致。
    • 如果你的 public_html 目录中没有 .htaccess 文件,或者其内容不正确,请创建一个新文件并粘贴上述代码。
    • 如果已经存在 .htaccess 文件,请备份原有内容,然后替换为上述代码。
  3. 上传文件: 使用 FTP 客户端或主机提供的文件管理器,将修改后的 .htaccess 文件上传到你的网站根目录(例如 public_html)。
  4. 清除 Laravel 缓存(可选但推荐): 部署后,清除 Laravel 应用程序的配置、路由和视图缓存通常是一个好习惯,以确保所有更改生效。如果你的主机支持 SSH 访问,可以运行:
    php artisan config:clear
    php artisan route:clear
    php artisan view:clear

    如果不支持 SSH,可能需要手动删除 bootstrap/cache 目录下的缓存文件,或者在 public/index.php 中临时添加 Artisan::call('cache:clear'); 等代码(完成后务必删除)。

注意事项

  • mod_rewrite 模块: 确保你的共享主机已启用 Apache 的 mod_rewrite 模块。大多数现代主机默认都会启用,但如果问题依然存在,请联系你的主机提供商确认。
  • 文件权限: 确保 .htaccess 文件的权限设置正确,通常是 644 或 664,以允许服务器读取。
  • 根目录结构: 上述解决方案假设你已将 Laravel 项目的 public 目录内容直接放在了网站的文档根目录(如 public_html)。如果你的部署结构不同,例如 public_html/laravel/public,那么 .htaccess 文件可能需要放置在 public_html 下,并且可能需要调整 Laravel 的 index.php 来正确加载框架核心。
  • 其他服务器类型: 如果你的主机使用的是 Nginx 而非 Apache,那么 .htaccess 文件将不起作用。Nginx 需要在其配置文件中进行类似的 URL 重写配置。

总结

通过在共享主机的文档根目录中正确配置 .htaccess 文件,可以有效解决 Laravel 项目部署后内部链接 404 的问题。这个 .htaccess 文件确保了所有非文件、非目录的请求都被重定向到 index.php,从而让 Laravel 的路由系统能够正常工作。理解其背后的原理和每个规则的作用,有助于在遇到类似问题时进行快速排查和解决。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

340

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

294

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

773

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

385

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

141

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

85

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

80

2025.08.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

578

2026.03.04

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43万人学习

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

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