【发布时间】:2016-01-21 13:23:53
【问题描述】:
我正在尝试通过带有 Ensembles 的 IIS 8 Webdav 后端使用同步。我遇到的问题是第一次同步工作正常,但是当我尝试第二次或在第二台设备(本例中为 iPad)上同步时,我收到服务器错误 405“方法不允许”。有没有人遇到过这个问题并让它工作,与 IIS Webdav 同步?
这是服务器响应的 allheaderfield 属性:
" UserInfo={NSLocalizedDescription=HTTP status code was {
Allow = "COPY, PROPFIND, DELETE, MOVE, PROPPATCH, LOCK, UNLOCK";
Connection = "Keep-Alive";
"Content-Length" = 1293;
"Content-Type" = "text/html";
Date = "Mon, 25 Jan 2016 12:02:07 GMT";
"Persistent-Auth" = true;
Server = "Microsoft-IIS/8.5";
"X-UA-Compatible" = "IE=8";
编辑: 可能毕竟这不是配置问题。我添加了一些日志,createDirectoryAtPath 方法给了我 HTTP 错误 405,这是原始代码:
- (void)createDirectoryAtPath:(NSString *)path completion:(CDECompletionBlock)completion{
NSMutableURLRequest *request = [self mutableURLRequestForPath:path];
request.HTTPMethod = @"MKCOL";
[request setValue:@"application/xml" forHTTPHeaderField:@"Content-Type"];
[self sendURLRequest:request completion:^(NSError *error, NSInteger statusCode, NSData *responseData) {
if (completion) completion(error);
}];}
这就是 directoryExistsAtPath 方法:
- (void)directoryExistsAtPath:(NSString *)path completion:(CDEDirectoryExistenceCallback)completion{
[self sendPropertyFindRequestForPath:path depth:0 completion:^(NSError *error, NSInteger statusCode, NSData *responseData) {
if (error && statusCode != 404) {
if (completion) completion(NO, error);
}
else if (statusCode == 404) {
if (completion) completion(NO, nil);
}
else {
CDEWebDavResponseParser *parser = [[CDEWebDavResponseParser alloc] initWithData:responseData];
BOOL succeeded = [parser parse:&error];
if (!succeeded) {
if (completion) completion(NO, error);
return;
}
BOOL isDir = [parser.cloudItems.lastObject isKindOfClass:[CDECloudDirectory class]];
if (completion) completion(isDir, nil);
}
}];}
如果我将末尾完成块中的第一个参数(当前是 isDir 变量)替换为 YES,则不会出现 405 错误。在记录 parser.clouditems.lastobject 时,我发现它经常(或总是?)空)。因此,将参数设置为 YES,会导致数据上传到我的 webdav,并且文件夹就位。但是,在第二个单元上进行测试(或在同一单元上重新安装应用程序),永远不会发生下载 - 永远不会调用 downloadFromPath,永远不会发送“GET”请求。
到目前为止,查看底层框架(主要是 CDECloudmanager)中的调用代码并没有将我带到任何地方。
由于 directoryExistsAtPath 是可选的,我尝试将其注释掉,但我不认为它有什么不同。
我注意到的另一件事是我在基线文件夹中获得了几个基线文件。根据 Ensembles 文档,应该只有一个。
有什么线索吗?
【问题讨论】:
-
你能不能试着找出是哪种方法?
-
我记录了响应的 allHeaderFields 属性,我将粘贴到原帖中。
-
我正在记录 CDEWebDavCloudFileSystem 文件中使用的动词,到目前为止,它看起来像 PUT 有效,但不是 MKCOL。
-
我现在可以看到 MKCOL 确实有效,当我尝试在第二台 iPad 上同步时,MKCOL 上的“方法不允许”出现。
-
嗯,恐怕我当然不是 WebDAV 专家。似乎它确实因平台而异。代码都在那里,所以我建议设置一些断点,看看你是否可以看到错误出现在类中的哪个位置,也许可以通过谷歌了解原因。
标签: ios core-data synchronization webdav ensembles