ios - MKMapView 无法加载带有 HTTP 410 错误的图 block

标签 ios macos mkmapview mapkit

MKMapView 有问题。 map 在放大时无法加载图 block 。

-(void)mapViewDidFailLoadingMap:(MKMapView *)mapView withError:(NSError *)error 

错误:

Domain=GEOErrorDomain Code=-204 "(null)" UserInfo={SimpleTileRequesterUnderlyingErrors=( "Error Domain=GEOErrorDomain Code=-204 \"(null)\" UserInfo={HTTPStatus=410, NSErrorFailingURLStringKey=http://gspe19.ls.apple.com/tile.vf?flags=1&style=20&size=2&scale=0&v=11037825&z=15&x=6205&y=12336&sid=0246704635757302674107153038443966765357&accessKey=1454685602_q3bVUYvHBdxsSo0A_j0fK7EyQ9b21NPShV7GRLzr4WFkkhxB4vO7%2BlXcGsXJ4zZHvhTaLVWsyPa3PlU60cDrmrFwmwCYBGrLA9mChV%2FHoRHoTU9AGI72VQP9UKZW%2B0GKqfRhpcw4xr%2F%2FTTVgJZ7wU4U4KnA8K2rVVQ%2FOfFHJq7OO4nYecTvy0ur4I9D3Sxf%2Btn9DcXU8agDRJignB}", ...

编辑: 似乎它以某种方式与缓存有关,但我不确定。在 Maps 应用程序中加载同一 map 区域后,此问题会消失一段时间。

提前致谢

最佳答案

我在苹果开发者论坛上分析描述了问题:https://forums.developer.apple.com/thread/43077


iOS 上的 MapKit 存在问题 - map 有时无法加载,有时会部分加载,为加载失败的图 block 显示普通网格。这个问题在整个系统范围内发生在每个使用 MapKit 的应用程序中,甚至在 Apple Maps 应用程序中也是如此。 iPhone (6+) 和 iPad(iPad Air、iPad Air 2、iPad Mini)以及一系列 iOS 版本(9.0、9.0.2、9.2.1)都会出现此问题。此外,本地图缩放比例较高时,这种情况似乎更常发生。该问题很难重现,因为它看起来是随机发生的,会在受影响的设备上持续一段时间然后突然消失。

我设法分析了网络流量并找到了这种奇怪行为的可能原因。与丢失的图 block 关联的网络请求失败,并返回 HTTP 状态代码 410 和空内容:

GET http://gspe19.ls.apple.com/tile.vf?flags=1&style=13&size=2&scale=0&v=11040322&z=15&x=17923&y=10756&sid=SOME_SID_1&accessKey=SOME_ACCESS_KEY_1 <- 410  
GET http://gspe19.ls.apple.com/tile.vf?flags=1&style=20&size=2&scale=0&v=11040322&z=15&x=17923&y=10756&sid=SOME_SID_1&accessKey=SOME_ACCESS_KEY_1 <- 410  
...  

'v' 参数似乎是一个 map 版本号,并且随着时间的推移而增长。看起来版本号会在“geo_manifest”网络调用后发生变化,这种情况时有发生:

GET https://gspe35-ssl.ls.apple.com/geo_manifest/dynamic/config?application=geod&application_version=1&country_code=PL&hardware=iPad4,2&os=ios&os_build=13C75&os_version=9.2  

下载新的 geo_manifest 后,版本号再次生效,每个瓦片请求成功结束,HTTP 状态码为 200:

GET http://gspe19.ls.apple.com/tile.vf?flags=1&style=13&size=2&scale=0&v=11040529&z=15&x=17923&y=10756&sid=SOME_SID_2&accessKey=SOME_ACCESS_KEY_2 <- 200  
GET http://gspe19.ls.apple.com/tile.vf?flags=1&style=20&size=2&scale=0&v=11040529&z=15&x=17923&y=10756&sid=SOME_SID_2&accessKey=SOME_ACCESS_KEY_2 <- 200  
...  

我使用 lldb 来确认,陈旧的 geo_manifest 是 410 响应的原因。我在使用 Xcode 显示症状的设备上运行了任意应用程序。 MKMapView 上缺少一些图 block ,网络流量中出现 410 响应。我关闭了 map ,暂停了 lldb 的执行,执行了一个似乎强制更新 geo_manifest 的私有(private) GeoService 框架方法:

(lldb) po [[GEOResourceManifestManager sharedManager] forceUpdate]  

恢复执行后,geo_manifest 更新请求出现在网络流量中。打开 map View 后,出现成功的磁贴响应并且 map 已完全加载。看起来 com.apple.geod 守护进程本身有时无法查询新的 geo_manifest。因为这个问题非常短暂,所以不可能在设备控制台日志中找到任何 com.apple.geod 错误。

出现以下问题:当 tile 请求产生 410 响应时,为什么 com.apple.geod、GeoServices 或 MapKit 不尝试查询新的 geo_manifest?这是一个已知问题吗? Apple 是否计划在未来的 iOS 版本中修复此问题?

编辑: 已在 iOS 10 ( https://openradar.appspot.com/radar?id=6075032430182400 ) 中修复。

关于ios - MKMapView 无法加载带有 HTTP 410 错误的图 block ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35226550/

相关文章:

ios - MKMapView:自定义 View 代替 Annotation Pin

ios - MK map 查看中心位置

android - 不同移动平台的文件格式是什么

macos - 相当于从 Mac OS X finder 打印 .docx 文件的命令行

xcode - macOS 应用公证在上传期间卡住

macos - mac 中 Visual Studio Code ("not"Visual Studio 中的符号 TreeView

ios - 缩放会增加 self.map.visibleMapRect.origin.x 和 y,但为什么呢?

ios - 如何在 swift 中使用实体关系从核心数据中获取数据?

android - iOS6、android 和位置 :fixed and scaling

ios - Alamofire.AFError.ResponseSerializationFailureReason.jsonSerializationFailed(错误域=NSCocoaErrorDomain 代码=3840