gpt4 book ai didi

ios - 如何判断 TWRequest performRequestWithHandler 是失败还是成功

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:20:18 25 4
gpt4 key购买 nike

我正在发布请求并检查错误,如下所示:

// Send request out on a background thread
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^(void) {
[postRequest performRequestWithHandler:^(NSData *responseData, NSHTTPURLResponse *urlResponse, NSError *error) {
if ([urlResponse statusCode] == 200) {
NSLog(@"Tweet Successful");
}else {
NSLog(@"Tweet Failed");
if (responseData) {
// Use the NSJSONSerialization class to parse the returned JSON
NSError *jsonError;
NSArray *requestResponse =
[NSJSONSerialization JSONObjectWithData:responseData
options:NSJSONReadingMutableLeaves
error:&jsonError];

if (requestResponse) {
NSLog(@"%@",requestResponse);
} else {
NSLog(@"%@",jsonError);
}
}
}
}];
});

就请求而言,它似乎工作正常。我的意图是在失败时将请求排队,并在以后重试,或者不重试,这取决于错误和到目前为止失败的尝试次数。我遇到的问题是,我发现它经常出现失败,出现错误 34“找不到页面”,而实际上请求确实成功了,已按预期发布,并且可以在 Twitter 流中清晰地看到。

现在,如果我不能相信返回的错误代码,那么我就不能真正继续并继续重试。我如何确定它是成功还是失败?

最近的观察:

最近,我试图直接从 Apple 照片应用程序发布一张照片,它向我发送了一条警告,内容为“Tweet 可能未成功”。这很有趣,因为这基本上是我在这种情况下唯一的选择。这让我觉得即使是 Apple 也不得不承认,当返回没有确认时,没有办法确定发布失败。

最佳答案

根据研究此问题时发现的每个示例,除了您正在使用的 API 外,没有一个使用任何其他 API,包括 this example from twitter's own documentation对于将照片发布到 API,它们都不会先检查 urlResponse 代码。

似乎完成的最多的是 this example from twitter's documentation其中执行 GET,然后处理响应。请注意,它首先检查 responseData,如果存在,则简单地视为成功。仅当没有 responseData 时才会尝试查看错误。该示例不会影响 urlResponse ......我在 10 分钟的谷歌搜索中看到的任何其他示例也不会。

(最后,我怀疑这是否重要,或者可能是因为您清理了显示示例,但是当您没有执行任何 UI 时,您正在处理主队列上的错误。您可以立即在处理程序中进行处理,并将您所做的任何后处理传递给您尝试显示它的任何 UI。我怀疑在主队列中对响应进行后处理而不是处理程序的队列(如此处引用的两个示例和我见过的所有其他示例中所示)确实会导致问题,但我想知道它是否会减少您看到的假阴性的发生率。至少,它会让您做出回应并且响应的任何 UI 显示更清晰、更高效。)

关于ios - 如何判断 TWRequest performRequestWithHandler 是失败还是成功,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12101433/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com