在共享主机上托管 Laravel 项目时,一个常见的挑战是确保 URL 不需要 /public 目录。这是在子目录中托管 Laravel 应用程序同时保持 URL 干净的分步指南。
require __DIR__.'/vendor/autoload.php'; $app = require_once __DIR__.'/bootstrap/app.php';
这告诉 Laravel 在项目的根目录而不是公共目录中查找必要的文件。
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。
如果您有 SSH 访问权限,在任何部署更改后清除缓存的配置和路由始终是一个好习惯。运行这些命令以确保不存在缓存的配置冲突:
php artisan route:cache php artisan config:cache php artisan cache:clear
现在,您应该能够在浏览器中访问您的 Laravel 应用程序,而无需在 URL 中添加 /public 。尝试访问如下路线:
https://www.yourdomain.com/hookbox-api/api/your-route
如果设置成功,加载应该不会出现任何错误。
通过将 index.php 和 .htaccess 移动到子目录的根目录并更新文件路径,您已经有效地将 Laravel 配置为在不暴露 URL 中的 /public 目录的情况下运行。此方法在使用共享主机时非常有用,因为它可以保持更清晰、更专业的 URL 结构。
以上是如何在共享主机的子目录中托管 Laravel 项目而不在 URL 中暴露“/public”的详细内容。更多信息请关注PHP中文网其他相关文章!