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 / 问题 / 866606
Accepted
embedded
embedded
Asked: 2017-08-03 22:52:33 +0800 CST2017-08-03 22:52:33 +0800 CST 2017-08-03 22:52:33 +0800 CST

webDAV 和 CORS

  • 772

我在我的 webServer 上看到了一些奇怪的行为。试图让 keeWeb 接受来自不同服务器上的 webDAV 共享的文件。如果我想添加一个以以下形式输入的 WebDAV 文件:

https://FQDN:8443/webdav/file.kdbx

我看到以下标头(FF 开发者工具标头 -> 响应标头):

Access-Control-Allow-Origin:"*"
Access-Control-Allow-Methods:"GET, HEAD, POST, PUT, OPTIONS, MOVE, DELETE, COPY, LOCK, UNLOCK"
Access-Control-Allow-Headers:"origin, content-type, cache-control, accept, authorization, if-match, destination, overwrite"
Access-Control-Allow-Credentials:"true"

但是,在网络选项卡中,我可以看到 401:请求方法:选项状态代码:401 未授权

似乎添加了 CORS 标头,但重写不起作用。我的 Apache 配置:

<Directory /var/www/html/webdav>

Header always set Access-Control-Allow-Origin *
Header always set Access-Control-Allow-Headers "origin, content-type, cache-control, accept, authorization, if-match, destination, overwrite"
Header always set Access-Control-Expose-Headers "ETag"
Header always set Access-Control-Allow-Methods "GET, HEAD, POST, PUT, OPTIONS, MOVE, DELETE, COPY, LOCK, UNLOCK"
Header always set Access-Control-Allow-Credentials "true"

RewriteEngine On
RewriteCond %{REQUEST_METHOD} OPTIONS
RewriteRule ^(.*)$ $1 [R=200,L]

        DAV On
        AuthType Basic
        AuthName "Authentication Required"
        AuthUserFile /etc/httpd/.htpasswd
        Require valid-user
</Directory>

我错过了什么,或者可能是重写在 Apache/2.4.6 (CentOS) 上不起作用。我真的不知道如何调试重写。有没有办法追踪这些事情?

apache-2.4
  • 2 2 个回答
  • 2141 Views

2 个回答

  • Voted
  1. Best Answer
    TommyPeanuts
    2018-05-14T07:19:20+08:002018-05-14T07:19:20+08:00

    OPTIONS 方法必须不受授权,所以将其放在需要身份验证的目录之外,如下所示:

    RewriteEngine on
    RewriteCond %{REQUEST_METHOD} OPTIONS
    RewriteRule ^(.*)$ blank.html [R=200,L,E=HTTP_ORIGIN:%{HTTP:ORIGIN}]
    
    <Directory "/path/to/your/directory">
      AuthType "Basic"
      AuthName "Password Manager"
      AuthBasicProvider file
      AuthUserFile "/your/htpasswd.file"
      Require user someuser
    
      DAV On
      Options Indexes
      Header always set Access-Control-Allow-Origin "*"
      Header always set Access-Control-Allow-Headers "origin, content-type, cache-control, accept, authorization, if-match, destination, overwrite"
      Header always set Access-Control-Expose-Headers "ETag"
      Header always set Access-Control-Allow-Methods "GET, HEAD, POST, PUT, OPTIONS, MOVE, DELETE, COPY, LOCK, UNLOCK"
      Header always set Access-Control-Allow-Credentials "true"
    </Directory>
    
    • 2
  2. Beri
    2017-08-09T00:24:27+08:002017-08-09T00:24:27+08:00

    我有完全相同的问题,几个月来我一直试图解决这个问题,我只是放弃了。服务器版本:Apache/2.4.10(Raspbian)除了来自 Keeweb 的 CORS 标头之外,我还尝试了这个(https://github.com/keeweb/keeweb/wiki/WebDAV-Config)

        Alias /KeePass /var/www/KeePass                                                                                                                                                                               
    
    
        <Directory /var/www/KeePass>                                                                                                                                                                              
            DAV On                                                                                                                                                                                                
            AuthType Digest                                                                                                                                                                                       
            AuthName "KeePass"                                                                                                                                                                                    
            AuthUserFile /var/www/passwd.dav                                                                                                                                                                      
            <LimitExcept OPTIONS>                                                                                                                                                                                 
            Require valid-user                                                                                                                                                                                    
            </LimitExcept>                                                                                                                                                                                        
       </Directory>
    
    • 1

相关问题

  • Apache2 - SSL 不工作

  • Apache <VirtualHost> 标签,如果客户端的 IP = x 则不重定向... 怎么做?

  • 我无法启用我的网站?[关闭]

  • SELinux 阻止 Apache 写入文件

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +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