Laravelのpublicをレンタルサーバーで別に配置したいとき
共有レンタルサーバーでLaravelを使う時、artisanが使えなくて、どうしようかなって思うときありますよね、多分w
Laravelの構成そのままpublic_htmlにアップしてもいいのだけど、そうなるとパスがおかしくなるし、なによりpublic_htmlの中にLaravelのコアは入れたくないですよね。
ということで、数時間格闘した記録をここに備忘録して残します。
Laravelの構成
Laravelは通常、こういった構成になってます。
この中のpublicが公開用のディレクトリでindex.phpや画像があり、サーバーで言うところのhtdocsだったり、public_htmlだったりします。
それ以外は、コアなので公開できる場所にはおかないように構成を変えていきたいと思います。
公開用に分ける
このpublicの中身をごっそりそのまま外に出したいと思います。
サーバーにpublic_htmlがある設定で作ります。
public_htmlには、publicの中身を全部入れます。
そして残りのLaravelフォルダとファイルは全てcoreというディレクトリを作って入れます。
こういった構成になります。
index.phpの編集
このままでは、index.phpがLaravelの内部にアクセスできないので、修正します。
if (file_exists($maintenance = __DIR__.'/../core/storage/framework/maintenance.php')) {
require $maintenance;
}
require __DIR__.'/../core/vendor/autoload.php';
$app = require_once __DIR__.'/../core/bootstrap/app.php';
これでindexからのアクセスは可能になりました。
app.phpの編集
$appでPublicの場所を指定しているので上書きしてあげます。
ディレクトリ指定は、最初にアクセスするbootstrapのapp.phpで行います。
$app->bind('path.public', function () {
return base_path('../public_html');
});
return $app;
publicへのパスは、base_pathの1階層上のpublic_htmlだよと書いています。
viteの編集
buildしたものであればこのままでも動くのですが、run devだとviteのエラーが出ます。
なので、vite.config.jsにPublicの場所を指定するコードを追加します。
import { defineConfig } from 'vite';
import laravel from 'laravel-vite-plugin';
export default defineConfig({
plugins: [
laravel({
publicDirectory: "../public_html", //追加部分
input: [
"resources/css/app.css",
"resources/scss/app.scss",
"resources/js/app.js",
],
refresh: true,
}),
],
});
とりあえずこれで現状は問題なく動作しています。
Discussion