为什么我的nimbus didImageLoad方法没有被调用?

时间:2012-01-31 22:23:14

标签: ios nimbus-ios

我是Nimbus的新手。现在我的应用程序试图通过此代码检索4张图片:

for (int i=minFoto; i<=maxFoto; i++) {

    NINetworkImageView* networkImageView = [self networkImageView];

    NSString *resourceURL = [NSString stringWithFormat:@"%@registration/rest/users/account_get_foto/%@?fotoId=%d", baseURL, ssid,  i];

    NSLog(resourceURL);

    [networkImageView setPathToNetworkImage:resourceURL
                             forDisplaySize: CGSizeMake(50, 50)
                                contentMode: networkImageView.contentMode];

我知道我的循环正常工作,因为我看到所有四个NSLog都正确出现。但是,我只获得了第一张图片。 networkImageViewDidStartLoad只被调用一次,并且没有调用didLoadImage或networkImageViewDidFailLoad。我认为didLoadImage永远不会被调用是很奇怪的。决不。我知道我有数据,因为我正在使用CharlieProxy(优秀的应用程序BTW,非常值得花50美元),它会在响应数据包中显示图像数据。

所以我从我的代表那里评论了这个:

[[Nimbus networkOperationQueue] setMaxConcurrentOperationCount:1];

正如您所料,我正在接受4次调用networkImageViewDidStartLoad,而且仍然是零到didLoadImage或networkImageViewDidFailLoad。

以下是我的请求标题(来自CharlieProxy)

GET /registration/rest/users/account_get_foto/fdbc2222-7b75-4ff4-b111-623e951e5b00?fotoId=134     HTTP/1.1
Host: -------------:8080
User-Agent: Ferret/1.0 CFNetwork/548.0.3 Darwin/11.2.0
Accept: */*
Accept-Language: en-us
Accept-Encoding: gzip, deflate
Connection: keep-alive

这是响应标题,显示“200 OK”

HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
X-Powered-By: Servlet/3.0; JBossAS-6
Content-Type: image/*
Content-Length: 461109
Date: Tue, 31 Jan 2012 21:12:33 GMT

âPNG (png data deleted...)

我现在有点困惑。我的服务器显然正在返回图像数据,但我的应用程序却没有得到它。有什么想法吗?

1 个答案:

答案 0 :(得分:0)

好吧,我找到了。不妨为未来的googlers提供答案。

我的networkImageView已经超出范围而且是ARC'd。有趣的是,我以为我把它保存了下来,但是这段代码被部分注释掉了!