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

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

在共享主机上托管 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”的详细内容,更多请关注其它相关文章!