webmanによる静的ファイルの処理
webmanは静的ファイルのアクセスをサポートしており、静的ファイルはすべてpublic
ディレクトリに配置されます。例えば、http://127.0.0.8787/upload/avatar.png
にアクセスすることは、実際には{主プロジェクトディレクトリ}/public/upload/avatar.png
にアクセスすることを意味します。
注意
/app/xx/ファイル名
で始まる静的ファイルのアクセスは、実際にはアプリケーションプラグインのpublic
ディレクトリにアクセスすることになります。つまり、{主プロジェクトディレクトリ}/public/app/
内のディレクトリへのアクセスはサポートされていません。
詳細については、アプリケーションプラグインを参照してください。
静的ファイルのサポートを無効にする
静的ファイルサポートが不要な場合は、config/static.php
を開き、enable
オプションをfalseに変更してください。無効にすると、すべての静的ファイルのアクセスは404が返されます。
静的ファイルディレクトリの変更
webmanはデフォルトでpublicディレクトリを静的ファイルのディレクトリとして使用します。変更する場合は、support/helpers.php
内のpublic_path()
ヘルパー関数を変更してください。
静的ファイルミドルウェア
webmanには静的ファイル用のミドルウェアが付属しています。位置はapp/middleware/StaticFile.php
です。時には、静的ファイルに対していくつかの処理を行う必要があります。例えば、静的ファイルにクロスオリジンHTTPヘッダーを追加したり、ドット(.
)で始まるファイルへのアクセスを禁止したりするために、このミドルウェアを使用できます。
app/middleware/StaticFile.php
の内容は以下のようになります:
<?php
namespace support\middleware;
use Webman\MiddlewareInterface;
use Webman\Http\Response;
use Webman\Http\Request;
class StaticFile implements MiddlewareInterface
{
public function process(Request $request, callable $next) : Response
{
// .で始まる隠しファイルへのアクセスを禁止する
if (strpos($request->path(), '/.') !== false) {
return response('<h1>403 forbidden</h1>', 403);
}
/** @var Response $response */
$response = $next($request);
// クロスオリジンHTTPヘッダーを追加
/*$response->withHeaders([
'Access-Control-Allow-Origin' => '*',
'Access-Control-Allow-Credentials' => 'true',
]);*/
return $response;
}
}
このミドルウェアを必要とする場合は、config/static.php
のmiddleware
オプションで有効化する必要があります。