模块 ngx_http_dav_module

示例配置
指令
     create_full_put_path
     dav_access
     dav_methods
     min_delete_depth

ngx_http_dav_module 模块用于通过 WebDAV 协议自动管理文件。该模块处理 HTTP 和 WebDAV 方法 PUT、DELETE、MKCOL、COPY 和 MOVE。

此模块默认情况下未构建,应使用 --with-http_dav_module 配置参数启用。

需要其他 WebDAV 方法才能运行的 WebDAV 客户端将无法与此模块一起使用。

示例配置

location / {
    root                  /data/www;

    client_body_temp_path /data/client_temp;

    dav_methods PUT DELETE MKCOL COPY MOVE;

    create_full_put_path  on;
    dav_access            group:rw  all:r;

    limit_except GET {
        allow 192.168.1.0/32;
        deny  all;
    }
}

指令

语法 create_full_put_path on | off;
默认值
create_full_put_path off;
上下文 httpserverlocation

WebDAV 规范仅允许在已存在的目录中创建文件。此指令允许创建所有必要的中间目录。

语法 dav_access users:permissions ...;
默认值
dav_access user:rw;
上下文 httpserverlocation

设置新创建的文件和目录的访问权限,例如:

dav_access user:rw group:rw all:r;

如果指定了任何 groupall 访问权限,则可以省略 user 权限。

dav_access group:rw all:r;

语法 dav_methods off | method ...;
默认值
dav_methods off;
上下文 httpserverlocation

允许指定的 HTTP 和 WebDAV 方法。参数 off 拒绝此模块处理的所有方法。支持以下方法:PUTDELETEMKCOLCOPYMOVE

使用 PUT 方法上传的文件首先写入临时文件,然后重命名该文件。从版本 0.8.9 开始,临时文件和持久性存储可以放在不同的文件系统上。但是,请注意,在这种情况下,文件将在两个文件系统之间复制,而不是廉价的重命名操作。因此,建议对于任何给定的位置,由 client_body_temp_path 指令设置的保存文件和保存临时文件的目录都放在同一个文件系统上。

使用 PUT 方法创建文件时,可以通过在“Date”标头字段中传递修改日期来指定修改日期。

语法 min_delete_depth number;
默认值
min_delete_depth 0;
上下文 httpserverlocation

允许 DELETE 方法删除文件,前提是请求路径中的元素数量不少于指定数量。例如,指令

min_delete_depth 4;

允许在以下请求中删除文件:

/users/00/00/name
/users/00/00/name/pic.jpg
/users/00/00/page.html

并拒绝删除:

/users/00/00