如何在Laravel项目中设置Leverage Browsing cache和Gzip Compression

时间:2018-06-12 09:15:54

标签: laravel-5 gzip browser-cache

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

任何帮助/建议都将受到赞赏。

提前谢谢。

1 个答案:

答案 0 :(得分:2)

启用gzip:

设置gzip压缩的方法有多种,具体取决于您是否拥有IIS或Apache服务器(或完全其他)。

对于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>

保存.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>

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

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