AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 69048
Accepted
EMP
EMP
Asked: 2009-09-27 19:02:32 +0800 CST2009-09-27 19:02:32 +0800 CST 2009-09-27 19:02:32 +0800 CST

受保护的 Apache Web 子目录要求输入两次密码

  • 772

我有一个带有密码保护的 Web 目录的 Apache 服务器。该目录有一个子目录,需要另一个密码,但任何可以访问子目录的人也应该可以访问父目录。那是:

  • /stuff - 允许用户“stuff”和“admin”
  • /stuff/admin - 只允许用户“admin”

所以我在 Apache 配置中设置了这种方式:

<Directory "/stuff">
   [AuthType Basic, AuthName, etc.]
   Require user stuff
   Require user admin
</Directory>

<Directory "/stuff/admin">
   [AuthType Basic, AuthName, etc.]
   Require user admin
</Directory>

从某种意义上说,我可以浏览到 /stuff 并以“admin”或“stuff”身份登录。但是,/stuff/admin 中的页面引用了父目录中的一些图像。我发现当我直接浏览到 /stuff/admin 并以“admin”身份登录时,浏览器仍然提示我输入另一个密码来加载这些图像。(我知道这是 /stuff 的提示,因为 AuthName 值不同。)

如何避免这种情况并允许有权访问 /stuff/admin 的用户只登录一次(作为“管理员”),而不是两次?

apache-2.2
  • 4 4 个回答
  • 5144 Views

4 个回答

  • Voted
  1. Best Answer
    EMP
    2009-10-03T17:34:21+08:002009-10-03T17:34:21+08:00

    问题原来是两个目录的不同AuthName值。我认为它的唯一目的是为用户提供有意义的提示。再次阅读文档后,发现它还有另一个目的:浏览器将自动尝试对具有相同 AuthName 的目录使用相同的凭据。

    所以在我的情况下发生的事情是,在通过/stuff/admin身份验证后,浏览器会请求/stuff/something-else,它会得到“401 Unauthorized”响应,但它甚至不会尝试相同的凭据。在我将 AuthName 更改为相同后,它会通过使用我之前验证过的“admin”用户名重试来自动响应 401,这很有效。

    • 5
  2. adric
    2009-09-28T18:55:41+08:002009-09-28T18:55:41+08:00

    您是否尝试过颠倒 htaccess 中节的顺序,以便更具体的情况优先?这可能会影响匹配并解决您的双重提示问题。

    要检查的另一件事是您是否可以使用 Realms 或 Groups 来简化,也许可以指定多个容器使用相同的身份验证后端。

    这(AAA)在 Apache 和 Apache2 之间是不同的,所以检查你有什么。以下是两组文档:

    http://httpd.apache.org/docs/1.3/howto/auth.html http://httpd.apache.org/docs/2.2/howto/auth.html

    h,

    亚德里克

    • 1
  3. Devin Ceartas
    2009-09-27T20:10:02+08:002009-09-27T20:10:02+08:00

    我还没有尝试过,但是将它们都更改为需要有效用户并将 admin .htaccess 指向一个组 .htpasswd 文件,该文件是 admin 子集和基本目录 .htaccess 到一个 .htpasswd 文件更大的超集?

    • 0
  4. Dennis Williamson
    2009-09-27T21:16:37+08:002009-09-27T21:16:37+08:00

    我相信当您在单独的行中列出内容时,会隐含“和”。尝试在同一行列出隐含“或”的用户:

    <Directory "/stuff">
       [AuthType Basic, AuthName, etc.]
       Require user stuff admin
    </Directory>
    
    • 0

相关问题

  • Apache Django Mod_Wsgi - 自动重新加载应用程序

  • Apache:对多个虚拟主机使用相同的目录指令

  • Apache 上的子域不工作 - 找不到服务器

  • PHP 作为 CGI 还是 Apache 模块?

  • 避免将某些丢失的文件记录到 Apache2 错误日志中

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve