Подписывайтесь на наш Telegram канал и будьте в курсе всех событий.

Hesko

22 677 Монеток

Настройка HTTPS в Laravel

После развертывания приложения на сервере одним из наиболее распространенных вопросов является настройка защищенного соединения через протокол HTTPS. Даже если приложение кажется работающим, могут возникнуть неожиданные проблемы с редиректами или смешанным контентом (Mixed Content: The page at '...' was loaded over HTTPS).

Как исправить и разобраться в причинах? Давайте рассмотрим, как настроить Laravel для работы по протоколу HTTPS.

Проверка настроек файла .env

Первым шагом следует убедиться, что значение переменной APP_URL в файле .env установлено корректно:

APP_URL = https://laravel.su/

В действительности параметр APP_URL не влияет на HTTP/HTTPS, но часто используется, например в ссылках.

Если значение верное, но проблемы с HTTPS все еще возникают, быстрым и ленивым решением будет принудительно указать использование HTTPS в сервис-провайдере вашего приложения. Вот пример кода, который активирует HTTPS только в случае, если среда выполнения приложения – production:

use Illuminate\Support\Facades\URL;

/**
 * Bootstrap any application services.
 */
public function boot(): void
{
    if ($this->app->environment('production')) {
        URL::forceScheme('https');
    }
}

Почему возникают проблемы с HTTPS?

Чтобы понять причину возникновения этих проблем, давайте разберемся, каким образом фреймворк определяет протокол для работы. Ведь приложение может работать как на HTTP, так и на HTTPS. Ответ на этот вопрос прост: каким был запрос, такой же будет и ответ.

При обработке запроса Laravel захватывает данные и в дальнейшим работает с ними через объект. Это позволяет избежать работы с глобальными переменными типа $_POST или $_SERVER.

use Illuminate\Http\Request;

$request = Request::capture();

Класс Illuminate\Http\Request основан на компоненте symfony/http-foundation, который содержит метод isSecure, проверяющий, является ли текущий протокол безопасным. С помощью проверки переменной $_SERVER['HTTPS'] как не пустой и не равной 'off’. Этот механизм почти не менялся с первой версии Symfony.

Зная эту информацию мы можем проверить, что ваш веб-сервер настроен на передачу правильного значения для $_SERVER['HTTPS']. Если это не происходит автоматически, необходимо внести соответствующие изменения в конфигурацию сервера.

Настройка каждого веб-сервера (Apache, Nginx, Caddy) выходит за рамки Laravel, однако вы можете найти соответствующую информацию в документации используемого программного обеспечения.

Облачные сервисы и балансировщики

Как мы уже выяснили, если трафик идёт по незащищенному соединению, приложение также будет считать, что работает по HTTP. Но есть случаи когда обмен может совершаться между различными внутренними или облачными сервисами, где в HTTPS нет необходимости.

Для решения этой проблемы был добавлен механизм “Доверенных прокси”, который выполняется ещё до проверки $_SERVER['HTTPS']. Его настройку для 10.x версии Laravel можно встретить в App\Http\Middleware\TrustProxies.

Например, если вы используете Cloudflare с их динамическим списком IP-адресов, имеет смысл настроить “доверять всем”:

class TrustProxies extends Middleware
{
    /**
     * The trusted proxies for this application.
     *
     * @var string|array
     */
    protected $proxies = '*';

    // ...
}

Дополнительную информацию можно найти в документации.

1

Laravel 11 будет включать маршрут для проверки состояния

В рамках выпуска 11ой версии Laravel появилась удобная возможность проверить работоспособность приложения с помощью конечной точки /up. Этот маршрут настраивается в новом файле bootstrap/app.php, где указывается параметр health, который по умолчанию включен в скелет Laravel 11:

Application::configure(basePath: dirname(__DIR__))
    ->withProviders()
    ->withRouting(
        web: __DIR__.'/../routes/web.php',
        // api: __DIR__.'/../routes/api.php',
        commands: __DIR__.'/../routes/console.php',
        // channels: __DIR__.'/../routes/channels.php',
        health: '/up',
    )
    // ...

При настройке параметра фреймворк автоматически добавит специальный маршрут. Переход на который запустит событие DiagnosingHealth , позволяющее выполнить дополнительные действия для диагностики состояния.

use Illuminate\Foundation\Events\DiagnosingHealth;
// ...
if (is_string($health)) {
    Route::middleware('web')->get($health, function () {
        Event::dispatch(new DiagnosingHealth);
        return View::file(__DIR__.'/../resources/health-up.blade.php');
    });
}

После настройки адрес /up будет возвращать анимированную страницу “Приложение работает” для браузера, что помогает разработчикам быстро убедиться в корректной работоспособности.

Страница состояния приложения в Laravel 11

0