登录
首页 >  文章 >  python教程

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

来源:dev.to

时间:2024-12-03 10:10:01 135浏览 收藏

从现在开始,我们要努力学习啦!今天我给大家带来《如何在共享主机的子目录中托管 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”》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>