带有自签名SSL证书的iOS MKTileOverlay

时间:2015-08-20 20:22:02

标签: ios ssl mktileoverlay

我为地图操作自己的tileserver。可通过HTTPS使用自签名证书访问此服务器。有没有机会使用MKTileOverlay

static NSString * const template = @"https://tile.myserverwithselfsignedcertificate.org/{z}/{x}/{y}.png";

MKTileOverlay *overlay = [[MKTileOverlay alloc] initWithURLTemplate:template];
overlay.canReplaceMapContent = YES;

[self.mapView addOverlay:overlay
                   level:MKOverlayLevelAboveLabels];

带有自签名证书。不幸的是,我在XCode日志窗口中收到一条错误消息,证明该证书无效。

对于直接NSURLConnection请求,我可以使用解决方案,例如:在这里:http://www.cocoanetics.com/2010/12/nsurlconnection-with-self-signed-certificates/

但这对我的自定义MKTileOverlay类不起作用。

有人知道这是否可行?

编辑2015年8月21日

我相信我必须将MKTileOverlay覆盖为类似的东西:

- (void)loadTileAtPath:(MKTileOverlayPath)path result:(void (^)(NSData *data, NSError *error))result
{
    NSURLRequest *request = [NSURLRequest requestWithURL:[self URLForTilePath:path]
                                                 cachePolicy:NSURLRequestReloadIgnoringCacheData timeoutInterval:20];
    connectionApi = [[NSURLConnection alloc] initWithRequest:request delegate:self startImmediately:YES];

}

- (void)connection:(NSURLConnection *)conn didReceiveData:(NSData *)data
{
    [myData appendData:data];
}

- (void)connectionDidFinishLoading:(NSURLConnection *)conn
{
    // myData includes now the required tile,
    // but how to pass it back to the result
    // block of the loadTileAtPath method???
}

有谁知道如何解决这个问题?

1 个答案:

答案 0 :(得分:0)

我能够解决它:

- (void)loadTileAtPath:(MKTileOverlayPath)path result:(void (^)(NSData *data, NSError *error))result
{
        NSURLRequest *request = [NSURLRequest requestWithURL:[self URLForTilePath:path]
                                                 cachePolicy:NSURLRequestReloadIgnoringCacheData timeoutInterval:20];
        if (!tileDict)
            tileDict = [[NSMutableDictionary alloc] initWithCapacity:100];

        NSURLConnection *connectionApi = [[NSURLConnection alloc] initWithRequest:request delegate:self startImmediately:YES];
        NSURL *myURL = [[connectionApi currentRequest] URL];

        NSNotificationCenter *center = [NSNotificationCenter defaultCenter];
        __block id tileNotification;
        tileNotification = [center addObserverForName:[NSString stringWithFormat:@"receivedTileFromInternet-%@", myURL]
                                                  object:nil
                                                   queue:nil
                                              usingBlock:^(NSNotification *notification)
                               {
                                   NSURL *myURL = [notification.userInfo objectForKey:@"tileUrl"];

                                   if ([tileDict objectForKey:myURL])
                                   {
                                       [[NSNotificationCenter defaultCenter] removeObserver:tileNotification];
                                       NSData *data = [tileDict objectForKey:myURL];

                                       result(data, nil);
                                   }
                               } ];
    }
}


- (void)connection:(NSURLConnection *)conn didReceiveData:(NSData *)data
{
    NSURL *myURL = [[conn currentRequest] URL];

    if (![tileDict objectForKey:myURL])
    {
        NSMutableData *singleTile = [[NSMutableData alloc] initWithData:data];
        [tileDict setObject:singleTile forKey:myURL];
    }
    else
    {
        [[tileDict objectForKey:myURL] appendData:data];
    }
}

- (void)connectionDidFinishLoading:(NSURLConnection *)conn
{
    NSURL *myURL = [[conn currentRequest] URL];
    if (![tileDict objectForKey:myURL])
    {
        NSLog(@"Tile leer???");
    }
    else
    {
        NSDictionary* userInfo = [NSDictionary dictionaryWithObjectsAndKeys:myURL, @"tileUrl", nil];
        NSNotificationCenter* nc = [NSNotificationCenter defaultCenter];
        [nc postNotificationName:[NSString stringWithFormat:@"receivedTileFromInternet-%@", myURL] object:self userInfo:userInfo];
    }
}