◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
在共享主机上托管 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 结构。
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。