.htaccess密码保护目录但允许图像文件类型

时间:2011-07-28 17:32:51

标签: php .htaccess

我需要使用.htaccess密码保护目录,我已成功完成。但是网站的前端被编程为链接到这个受密码保护的目录(不是我)中的图像,但是当网页试图访问这些图像时,它会提示用户登录。

是否可以使用密码保护该目录,但允许访问任何图像文件类型,如* .jpg和* .gif?

我目前的.htaccess代码是这样的:

AuthName "Secure Area"
AuthUserFile "/home/siteuser/.htpasswds/public_html/admin/passwd"
AuthType Basic
require valid-user

感谢您的帮助!

4 个答案:

答案 0 :(得分:16)

AuthName "Secure Area"
AuthUserFile "/home/siteuser/.htpasswds/public_html/admin/passwd"
AuthType Basic
require valid-user
<FilesMatch "\.(png|jpe?g|gif)$">
  Satisfy Any
  Allow from all
</FilesMatch>

编辑以融入Shef的改进

答案 1 :(得分:1)

您可以检查所有不同的配置选项.htaccess会在以下网站中为您提供:

Stupid htaccess Tricks

答案 2 :(得分:0)

您是否尝试将其放入Filematch?

<FilesMatch "^.*(png|jpe?g|gif)$">
AuthName "Secure Area"
AuthUserFile "/home/siteuser/.htpasswds/public_html/admin/passwd"
AuthType Basic
require valid-user
</FilesMatch>

答案 3 :(得分:-1)

您可以尝试编写图像显示代理:

  • 保持目录,就像你现在一样,使用密码保护。
  • 在链接图像的网站根目录上的.htaccess中,为所需的图像类型添加重写规则。此规则应将调用重定向到PHP处理程序脚本。
  • 该脚本应评估所请求的路径,从文件系统加载文件,扣除其标头并使用header()将其发送到客户端,然后图像文件的内容echo file_get_contents()应该执行

PHP不受.htaccess的影响,因此它应该能够读取您需要的文件并将其代理给最终用户。