3

浏览器如何实现对应用程序缓存清单文件的请求,它与请求其他文件的方式有什么不同?

我之所以问,是因为在 IIS 7 中使用 Windows/NTLM 身份验证时,我看到了我不会预料到的行为。情况是​​我有一个定义了清单文件的站点。使用匿名身份验证,一切都按预期工作——站点加载并可以脱机使用。

当我禁用匿名并启用 Windows 身份验证时,该站点将在身份验证后正常加载,但我会在控制台(在 Chrome 或 iPad 2 上)中看到一个错误,指出无法获取清单文件。

在 iPad 上,错误是无法获取应用程序缓存文件。在 Chrome 中,具体错误是“应用程序缓存错误事件:清单提取失败 (401)”。在这两个实例中,我都可以在 Web 服务器日志中看到 401 响应代码。

为什么这种行为似乎出乎意料是对所有其他资源(CSS、JavaScript、图像)的请求都按预期工作。此外,我可以浏览到我的 .appcache 文件并加载它。

谁能解释发生了什么?

有没有其他人遇到过这个问题并找到了解决方案?

4

3 回答 3

1

不确定这是否仍然相关,但我也遇到了这个问题。

当我的站点发出 AJAX 请求时,一旦页面加载,我会被要求提供凭据以进行请求。一旦发生这种情况,运行applicationCache.update()会导致应用程序缓存正确更新。

因此,作为一种变通方法,也许可以尝试向某个东西发出 AJAX 请求,以便提示用户输入凭据,然后调用applicationCache.update().

于 2013-05-20T15:31:05.180 回答
0

我知道这是一个老问题,但我遇到了完全相同的问题,导致我来到这里。

我的设置是:
服务器 - IIS8
身份验证 - Windows
匿名身份验证 - 启用(这样做是为了无论身份验证如何都可以获取我的动态清单,然后我必须用上面的设置来装饰所有其他控制器[Authorize]

通过上述设置,应用程序将正确缓存但是,当从缓存加载时,如果清单有更新,则某些部分没有获取(例如授权内容),因为用户没有“登录”,因此整个更新甚至失败。

我的解决方案是向授权资源添加 ajax 调用,这样当用户在线时,他们会被提示登录,这意味着下次更新缓存时,他们会再次获得授权。

于 2014-01-14T04:07:21.867 回答
0

我也遇到过这个问题。正如您所描述的那样,但我在 Apache 上使用基本身份验证。我将尝试公开 mainfest 文件。

于 2012-03-09T19:40:55.700 回答