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.