HstsMiddleware.php 809 B

12345678910111213141516171819202122232425262728293031
  1. <?php
  2. namespace App\Http\Middleware;
  3. use Closure;
  4. use Illuminate\Http\Request;
  5. class HstsMiddleware
  6. {
  7. /**
  8. * Handle an incoming request.
  9. *
  10. * @param \Illuminate\Http\Request $request
  11. * @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next
  12. * @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse
  13. */
  14. public function handle(Request $request, Closure $next)
  15. {
  16. $response = $next($request);
  17. // Applica l’header HSTS solo se la richiesta è HTTPS
  18. if ($request->isSecure()) {
  19. $response->headers->set(
  20. 'Strict-Transport-Security',
  21. 'max-age=31536000; includeSubDomains'
  22. );
  23. }
  24. return $response;
  25. }
  26. }