我有一个适用于 windows 和 OSX 10.8 版本的 webdav 服务器实现。自 OS X 10.9 升级以来,许多 webdav 操作(包括使用 Finder 将文件拖到 webdav 挂载上以及使用 MS Office 应用程序(Microsoft Word、Office、Powerpoint)编辑文件)都已停止工作。
查看客户端 <-> webdav 服务器流量,似乎在获取文件上的 LOCK 后,客户端在对服务器的后续请求中没有提供锁定令牌,导致后续操作出现 423 响应。根据 webdav 规范,客户端需要在后续命令中向服务器提供文件锁定令牌。
我确认这不是 10.8 或更早版本的问题。
文件拖放到 Finder webdav mount 显示以下请求和响应序列:
PROPFIND /webdav/Private/a123/test.pptx 404
PROPFIND /webdav/Private/a123/test.pptx
PUT /egnyte-internal/webdav/Private/a123/test.pptx 201
PROPFIND /webdav/Private/a123/._test.pptx 404
LOCK /webdav/Private/a123/test.pptx 200
UNLOCK /webdav/Private/a123/test.pptx 204
PROPFIND /webdav/Private/a123/._test.pptx 404
LOCK /webdav/Private/a123/test.pptx 200
UNLOCK /webdav/Private/a123/test.pptx 423
查看此序列的 wireshark 输出,第二个解锁请求不包含 Lock-Token 标头。此时,system.log 显示错误“unexpected statusCode 423”并挂载断开连接。
这是 UNLOCK 请求标头,缺少 Lock-Token:
UNLOCK /webdav/Private/a123/test.pptx HTTP/1.1
Host: localhost:10001
Accept: */*
Authorization: Basic YWRtaTeyhsbaksVusjhs9tZTEyMw==
Content-Length: 0
Connection: keep-alive
User-Agent: WebDAVFS/3.0.0 (03008000) Darwin/13.0.0 (x86_64)
\r\n
有没有其他人看到这个问题并有解决方案?
谢谢