如何在 Laravel 项目中设置杠杆浏览缓存和 Gzip 压缩

ani*_*nil 5 gzip browser-cache laravel-5

我正在尝试启用Gzip 压缩并利用 Laravel 中的浏览器缓存进行网站优化。我不知道如何在 Laravel 中启用它们。

任何帮助/建议将不胜感激。

提前致谢。

小智 9

启用 gzip:

根据您是否拥有 IIS 或 Apache 服务器(或其他任何东西),有多种设置 gzip 压缩的方法。

对于 Apache:您需要将以下行添加到 .htaccess 文件中:

<IfModule mod_deflate.c>
  # Compress HTML, CSS, JavaScript, Text, XML and fonts
  AddOutputFilterByType DEFLATE application/javascript
  AddOutputFilterByType DEFLATE application/rss+xml
  AddOutputFilterByType DEFLATE application/vnd.ms-fontobject
  AddOutputFilterByType DEFLATE application/x-font
  AddOutputFilterByType DEFLATE application/x-font-opentype
  AddOutputFilterByType DEFLATE application/x-font-otf
  AddOutputFilterByType DEFLATE application/x-font-truetype
  AddOutputFilterByType DEFLATE application/x-font-ttf
  AddOutputFilterByType DEFLATE application/x-javascript
  AddOutputFilterByType DEFLATE application/xhtml+xml
  AddOutputFilterByType DEFLATE application/xml
  AddOutputFilterByType DEFLATE font/opentype
  AddOutputFilterByType DEFLATE font/otf
  AddOutputFilterByType DEFLATE font/ttf
  AddOutputFilterByType DEFLATE image/svg+xml
  AddOutputFilterByType DEFLATE image/x-icon
  AddOutputFilterByType DEFLATE text/css
  AddOutputFilterByType DEFLATE text/html
  AddOutputFilterByType DEFLATE text/javascript
  AddOutputFilterByType DEFLATE text/plain
  AddOutputFilterByType DEFLATE text/xml

  # Remove browser bugs (only needed for really old browsers)
  BrowserMatch ^Mozilla/4 gzip-only-text/html
  BrowserMatch ^Mozilla/4\.0[678] no-gzip
  BrowserMatch \bMSIE !no-gzip !gzip-only-text/html
  Header append Vary User-Agent
</IfModule>
Run Code Online (Sandbox Code Playgroud)

保存 .htaccess 文件后,在Google Page Speed InsightsGtmetrix 中再次测试您的网站 ,以确保它已被正确压缩。

启用杠杆浏览器缓存:

再次将以下代码添加到您的 .htaccess 文件中。

<IfModule mod_expires.c>
  ExpiresActive On

  # Images
  ExpiresByType image/jpeg "access plus 1 year"
  ExpiresByType image/gif "access plus 1 year"
  ExpiresByType image/png "access plus 1 year"
  ExpiresByType image/webp "access plus 1 year"
  ExpiresByType image/svg+xml "access plus 1 year"
  ExpiresByType image/x-icon "access plus 1 year"

  # Video
  ExpiresByType video/mp4 "access plus 1 year"
  ExpiresByType video/mpeg "access plus 1 year"

  # CSS, JavaScript
  ExpiresByType text/css "access plus 1 month"
  ExpiresByType text/javascript "access plus 1 month"
  ExpiresByType application/javascript "access plus 1 month"

  # Others
  ExpiresByType application/pdf "access plus 1 month"
  ExpiresByType application/x-shockwave-flash "access plus 1 month"
</IfModule>
Run Code Online (Sandbox Code Playgroud)

小心 您在启用浏览器缓存时要小心,因为如果您在某些文件上设置的参数太长,用户可能无法在更新后获得您网站的最新版本。

如果您正在与设计师合作对您的网站进行更改,这一点尤其重要——他们可能已经进行了更改,但您还看不到它们,因为已更改的元素已缓存在您的浏览器中。

  • 这就是为什么开发人员会在链接或脚本标签上使用参数来强制发出新请求 (2认同)