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 в качестве каталога статических файлов. Если нужно изменить, откройте помощник public_path()
в файле support/helpers.php
.
Промежуточное ПО для статических файлов
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);
// Добавить заголовок для кросс-доменных запросов
/*$response->withHeaders([
'Access-Control-Allow-Origin' => '*',
'Access-Control-Allow-Credentials' => 'true',
]);*/
return $response;
}
}
Если это промежуточное ПО необходимо, нужно включить его в опции middleware
файла config/static.php
.