Функция route в Laravel генерирует URL-адреса с использованием протокола HTTP, а не HTTPS, по умолчанию.
Причина, по которой это происходит, связана с тем, что Laravel предполагает, что ваше приложение будет находиться за обратным прокси-сервером, который заботится о проведении безопасного соединения через HTTPS. В этом случае протокол HTTPS уже будет добавлен прокси-сервером, и Laravel предоставляет гибкость использования протоколов в конфигурации для разработчиков.
Если ваше приложение работает без прокси-сервера, и вы хотите, чтобы функция route генерировала URL-адреса с использованием протокола HTTPS, вы должны сконфигурировать ваш сервер и Laravel соответствующим образом.
Если вы используете веб-сервер Apache, вы можете добавить следующую строку в .htaccess-файл в корневой папке вашего проекта Laravel:
SetEnvIf X-Forwarded-Proto https HTTPS=on
Это позволит Laravel распознавать, что ваше приложение работает с использованием HTTPS, и, следовательно, функция route будет генерировать URL-адреса с использованием этого протокола.
Если вы используете веб-сервер Nginx, вам нужно добавить следующую строку в ваш конфигурационный файл в блок server:
proxy_set_header X-Forwarded-Proto https;
Это также позволяет Laravel распознавать, что приложение работает с использованием HTTPS.
Кроме того, есть и другие способы для работы с HTTPS в Laravel, например, вы можете использовать функцию secure_asset() для генерации URL-адресов для статических ресурсов (например, изображений, файлов CSS и JS) с использованием протокола HTTPS.
{{ secure_asset('/path/to/asset') }}
Также Laravel предоставляет возможность настройки защищенных маршрутов (HTTPS) с помощью механизма маршрутизации, используя методы middleware и группы маршрутов.
Как видно, в Laravel есть несколько способов работы с HTTPS, и все они предназначены для обеспечения гибкости и удобства для разработчиков и администраторов. Вам нужно выбрать тот, который лучше всего соответствует вашим требованиям и настройкам вашего сервера.