¿Cómo habilitar la compresión Gzip o Deflate a través de .htaccess y cuál es el mejor en estos días? Se necesitan ejemplos de código.
¿Cómo habilitar la compresión Gzip o Deflate a través de .htaccess y cuál es el mejor en estos días? Se necesitan ejemplos de código.
HTML5 Boilerplate ( http://html5boilerplate.com ) ofrece lo que parece ser la mejor y más efectiva solución junto con muchos otros, como el almacenamiento en caché, los tipos MIME, etc. Muy recomendable.
<IfModule mod_deflate.c>
# Force compression for mangled headers.
# http://developer.yahoo.com/blogs/ydn/posts/2010/12/pushing-beyond-gzipping
<IfModule mod_setenvif.c>
<IfModule mod_headers.c>
SetEnvIfNoCase ^(Accept-EncodXng|X-cept-Encoding|X{15}|~{15}|-{15})$ ^((gzip|deflate)\s*,?\s*)+|[X~-]{4,13}$ HAVE_Accept-Encoding
RequestHeader append Accept-Encoding "gzip,deflate" env=HAVE_Accept-Encoding
</IfModule>
</IfModule>
# Compress all output labeled with one of the following MIME-types
# (for Apache versions below 2.3.7, you don't need to enable `mod_filter`
# and can remove the `<IfModule mod_filter.c>` and `</IfModule>` lines
# as `AddOutputFilterByType` is still in the core directives).
<IfModule mod_filter.c>
AddOutputFilterByType DEFLATE application/atom+xml \
application/javascript \
application/json \
application/rss+xml \
application/vnd.ms-fontobject \
application/x-font-ttf \
application/x-web-app-manifest+json \
application/xhtml+xml \
application/xml \
font/opentype \
image/svg+xml \
image/x-icon \
text/css \
text/html \
text/plain \
text/x-component \
text/xml
</IfModule>
</IfModule>
EDITAR: dado que esta pregunta y respuesta siguen votando después de un par de años, estoy poniendo el enlace de configuración del servidor H5BP para una optimización más completa .
EDITAR: enlace fijo a https://github.com/h5bp/server-configs-apache
Consulte la documentación de Apache mod_deflate , específicamente, el ejemplo de " comprimir todo excepto imágenes ". Me ha funcionado bien y se incluiría en un .htaccess
archivo de la siguiente manera:
<IfModule mod_deflate.c>
# Insert filter
SetOutputFilter DEFLATE
# Netscape 4.x has some problems...
BrowserMatch ^Mozilla/4 gzip-only-text/html
# Netscape 4.06-4.08 have some more problems
BrowserMatch ^Mozilla/4\.0[678] no-gzip
# MSIE masquerades as Netscape, but it is fine
# BrowserMatch \bMSIE !no-gzip !gzip-only-text/html
# NOTE: Due to a bug in mod_setenvif up to Apache 2.0.48
# the above regex won't work. You can use the following
# workaround to get the desired effect:
BrowserMatch \bMSI[E] !no-gzip !gzip-only-text/html
# Don't compress images
SetEnvIfNoCase Request_URI \
\.(?:gif|jpe?g|png)$ no-gzip dont-vary
# Make sure proxies don't deliver the wrong content
Header append Vary User-Agent env=!dont-vary
</IfModule>
Y, por supuesto, asegúrese de tener lo siguiente en su httpd.conf
archivo para habilitar mod_deflate
:
LoadModule deflate_module libexec/apache2/mod_deflate.so
Permití desinflar en activos estáticos en mi sitio (por tipo MIME) usando lo siguiente agregado al .htaccess
archivo en la raíz de mi public_html
directorio:
<ifModule mod_deflate.c>
AddOutputFilterByType DEFLATE text/html text/xml text/css text/plain
AddOutputFilterByType DEFLATE text/javascript application/javascript application/x-javascript application/json
</ifModule>
También puede habilitarlo por extensión de archivo, aunque no tengo la sintaxis para eso a mano.