如何在iOS中缓存带有图像的整个网页

时间:2011-07-14 15:53:42

标签: iphone ios ipad caching uiwebview

我正在开发iOS上的图像文本混合页面。我知道我可以使用UIWebView来实现目标。但问题是,用户可能需要离线阅读页面。 对于文本部分,我可以将html保存到磁盘并将其加载到脱机模式。 但图像怎么样?是否可以将图像缓存到磁盘,UIWebView仍然可以显示它们?

谢谢!

1 个答案:

答案 0 :(得分:15)

ASIHTTPRequest project有一个名为ASIWebPageRequest的课程,旨在完全按照您的意愿行事。如果您可以为项目添加额外的依赖项,那么我认为这对您来说是一个很好的解决方案:ASIWebPageRequest

在我上面喜欢的页面上有一些如何使用它的好例子,但为了完整起见我会在其中包含其中一个:

- (IBAction)loadURL:(NSURL *)url
{
   // Assume request is a property of our controller
   // First, we'll cancel any in-progress page load
   [[self request] setDelegate:nil];
   [[self request] cancel];

   [self setRequest:[ASIWebPageRequest requestWithURL:url]];
   [[self request] setDelegate:self];
   [[self request] setDidFailSelector:@selector(webPageFetchFailed:)];
   [[self request] setDidFinishSelector:@selector(webPageFetchSucceeded:)];

   // Tell the request to embed external resources directly in the page
   [[self request] setUrlReplacementMode:ASIReplaceExternalResourcesWithData];

   // It is strongly recommended you use a download cache with ASIWebPageRequest
   // When using a cache, external resources are automatically stored in the cache
   // and can be pulled from the cache on subsequent page loads
   [[self request] setDownloadCache:[ASIDownloadCache sharedCache]];

   // Ask the download cache for a place to store the cached data
   // This is the most efficient way for an ASIWebPageRequest to store a web page
   [[self request] setDownloadDestinationPath:
      [[ASIDownloadCache sharedCache] pathToStoreCachedResponseDataForRequest:[self request]]];

   [[self request] startAsynchronous];
}

- (void)webPageFetchFailed:(ASIHTTPRequest *)theRequest
{
   // Obviously you should handle the error properly...
   NSLog(@"%@",[theRequest error]);
}

- (void)webPageFetchSucceeded:(ASIHTTPRequest *)theRequest
{
   NSString *response = [NSString stringWithContentsOfFile:
      [theRequest downloadDestinationPath] encoding:[theRequest responseEncoding] error:nil];
   // Note we're setting the baseURL to the url of the page we downloaded. This is important!
   [webView loadHTMLString:response baseURL:[request url]];
}