3

我想设置一个正则表达式,禁止对不以以下模式结尾的图像进行热链接:-200.jpg

“200”实际上可以是“150”或“250”或100-999之间的任何数字(即3个字符)。.jpg 可以是.jpeg 或.png,.gif 允许盗链。

我从这样的事情开始:

RewriteCond %{HTTP_REFERER} !^$
RewriteCond %{HTTP_REFERER} !^http(s)?://(.+\.)?mywebsite\.com/ [NC]
RewriteRule [^0-9]{3}\.(jpe?g|png)$ /img/hotlink.gif [NC,R,L]

例如: 这应该被允许: h*ttp://mywebsite.tld/dir/dir/hello_sdfk456er_142.jpg-200.jpg而这应该被拒绝:h*ttp://mywebsite.tld/dir/dir/hello_sdfk456er_142.jpg

但这不起作用。

另外,请考虑以下事项:

我正在使用 url_rewriting 以便显示图像的 html 页面就像h*ttp://mywebsite.tld/username/1337.jpg 1337 代表数据库中图像的 id 一样。我之所以强调这种微妙之处,是因为有这样一条规则:

RewriteRule ![0-9]{3}\.(jpe?g|png)$ /img/hotlink.gif [NC,R,L]

行不通。

编辑:

我刚刚解决了它添加了一些例外:

RewriteCond %{HTTP_REFERER} !^$
RewriteCond %{HTTP_REFERER} !^http(s)?://(.+\.)?mywebsite\.com/ [NC]
RewriteCond %{REQUEST_URI}  !-[0-9]{3}\.(jpe?g|gif|png)$ [NC]
RewriteCond %{REQUEST_URI}  !/[0-9]+\.(jpe?g|gif|png)$ [NC]
RewriteRule \.(jpe?g|png)$  /img/hotlink.gif [NC,R,L]

如果您知道“更性感”的方式,请告诉我。无论如何都要感谢那个尝试过的人(删除了他的消息?)

4

2 回答 2

1

您的解决方案有两个缺陷:

  1. 第 4 行/[0-9]+也将允许热链接图像被命名为 just 200.jpg(无连字符)。
  2. 缺少 RewriteRule 条件,因此不允许盗链.gif图像。

这是一个更新的版本:

RewriteCond %{HTTP_REFERER} !^$
RewriteCond %{HTTP_REFERER} !^https?://(.+\.)?mywebsite\.com/ [NC]
RewriteCond %{REQUEST_URI}  !-[0-9]{3}\.(jpe?g|gif|png)$ [NC]
RewriteRule .* http://mywebsite.com/img/hotlink.gif [NC,R,L]

您可以按如下方式阅读:

  1. 如果referrer不为空
  2. 推荐人不是我的网站
  3. 并且请求的图像不以允许的模式结尾(例如 -123.gif)
  4. 然后显示一个hotlink.gif
于 2012-12-07T00:02:27.527 回答
0
RewriteCond %{HTTP_REFERER} !^$
RewriteCond %{HTTP_REFERER} !^http(s)?://(.+\.)?mywebsite\.com/ [NC]
RewriteCond %{REQUEST_URI}  !-[0-9]{3}\.(jpe?g|gif|png)$ [NC]
RewriteCond %{REQUEST_URI}  !/[0-9]+\.(jpe?g|gif|png)$ [NC]
RewriteRule \.(jpe?g|png)$  /img/hotlink.gif [NC,R,L]
于 2012-12-06T20:45:17.583 回答