首页  >  文章  >  后端开发  >  如何在共享主机的子目录中托管 Laravel 项目而不在 URL 中暴露“/public”

如何在共享主机的子目录中托管 Laravel 项目而不在 URL 中暴露“/public”

Barbara Streisand
Barbara Streisand原创
2024-11-07 20:07:03996浏览

How to Host a Laravel Project in a Subdirectory on Shared Hosting without Exposing `/public` in the URL

在共享主机上托管 Laravel 项目时,一个常见的挑战是确保 URL 不需要 /public 目录。这是在子目录中托管 Laravel 应用程序同时保持 URL 干净的分步指南。

第 1 步:将 Laravel 项目上传到服务器

  1. 登录您的托管帐户并访问您的文件管理器。
  2. 导航到 public_html 文件夹或您网站的主目录。
  3. 为您的 Laravel 项目创建一个新文件夹(子目录)。在此示例中,我们将其命名为 hookbox-api。
  4. 将整个 Laravel 项目上传到 hookbox-api 文件夹。

步骤2:将index.php移动到子目录的根目录

  1. 打开 hookbox-api/public 文件夹。
  2. 将index.php文件从public复制(或移动)到hookbox-api的根目录。
  3. 打开hookbox-api根目录中复制的index.php文件并更新文件路径,如下所示:
   require __DIR__.'/vendor/autoload.php';
   $app = require_once __DIR__.'/bootstrap/app.php';

这告诉 Laravel 在项目的根目录而不是公共目录中查找必要的文件。

步骤 3:将 .htaccess 文件移至子目录的根目录

  1. 接下来,将 .htaccess 文件从 public 文件夹移动到 hookbox-api 的根目录。
  2. 将此 .htaccess 文件的内容替换为以下内容:
   RewriteEngine On

   # Force HTTPS
   RewriteCond %{HTTPS} off
   RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301]

   # Redirect all requests to index.php
   RewriteCond %{REQUEST_FILENAME} !-d
   RewriteCond %{REQUEST_FILENAME} !-f
   RewriteRule ^ index.php [L]

此代码确保所有传入请求都定向到 hookbox-api 文件夹中的index.php。如果您的网站启用了 SSL,它还会强制使用 HTTPS。

第 4 步:清除 Laravel 的缓存(可选但推荐)

如果您有 SSH 访问权限,在任何部署更改后清除缓存的配置和路由始终是一个好习惯。运行这些命令以确保不存在缓存的配置冲突:

php artisan route:cache
php artisan config:cache
php artisan cache:clear

第 5 步:测试您的设置

现在,您应该能够在浏览器中访问您的 Laravel 应用程序,而无需在 URL 中添加 /public 。尝试访问如下路线:

https://www.yourdomain.com/hookbox-api/api/your-route

如果设置成功,加载应该不会出现任何错误。

结论

通过将 index.php 和 .htaccess 移动到子目录的根目录并更新文件路径,您已经有效地将 Laravel 配置为在不暴露 URL 中的 /public 目录的情况下运行。此方法在使用共享主机时非常有用,因为它可以保持更清晰、更专业的 URL 结构。

以上是如何在共享主机的子目录中托管 Laravel 项目而不在 URL 中暴露“/public”的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn