【发布时间】:2021-04-03 12:02:15
【问题描述】:
我生成了 *.webp 文件,这些文件的名称与它们的 png 或 jpg 源完全相同。然后我将此添加到我的 .htaccess 中:
<IfModule mod_rewrite.c>
RewriteEngine On
# Does browser explicitly support webp?
RewriteCond %{HTTP_USER_AGENT} Chrome [OR]
# OR Is request from Page Speed
RewriteCond %{HTTP_USER_AGENT} "Google Page Speed Insights" [OR]
# OR does this browser explicitly support webp
RewriteCond %{HTTP_ACCEPT} image/webp [OR]
# AND does a webp image exists?
RewriteCond %{DOCUMENT_ROOT}/$1\.webp -f
# THEN send the webp image and set the env var webp
RewriteRule (.+\.(?:jpe?g|png))$ $1.webp [NC,L]
</IfModule>
<IfModule mod_mime.c>
AddType image/webp .webp
</IfModule>
我的期望:
所有 jpg 文件都正常加载,例如 /test/marc.jpg 如果存在同名的 webp,则通过 url /test/marc.jpg 提供 webp 文件
这个作品的webp文件是存在的。但是如果我删除一个 webp 文件,我会在 jpg 或 png url 上得到一个 404。即使是旧的 jpg 或 png 网址也会给出 404。示例:
/www/media/
.htaccess
marc.jpg
marc.webp
http://domain/marc.jpg 服务于 webp。我在禁用缓存的情况下从 chrome 进行测试。当我删除 marc.webp 时,我在 http://domain/marc.jpg 上得到 404 为什么? RewriteCond %{DOCUMENT_ROOT}/$1.webp -f 应该可以解决这个问题,对吧?
【问题讨论】:
-
看这个,我看不出它是怎么工作的,因为 $1 将引用整个“marc.jpg”,所以尝试加载“marc.jpg.webp”,不是“marc.webp”。我也不知道你可以像这样在 RewriteCond 中使用 RewriteRule 中的 $1,但也许你可以?
-
原始脚本开头有这个:
RewriteEngine On RewriteBase / 但我删除了 RewriteBase。但是使用 RewriteBase 它根本不起作用。即使在我的根目录中 / -
而且 /test/marc.jpg.webp 也不起作用。
-
附带说明,测试用户代理,尤其是像“Chrome”这样通用的东西,是个坏主意;真正的 Google Chrome 浏览器应该发送正确的 Accept 标头(无论如何您都可以进一步测试),并且没有特别的理由假设任何其他浏览器在其用户代理中都可以正确处理 WebP 图像。
标签: .htaccess mod-rewrite webp