создать асинхронный запрос - PullRequest
0 голосов
/ 29 марта 2012

Я пытаюсь реализовать асинхронный запрос.Я сделал свое исследование, и это лучшее, что я получил, но код полон ошибок, которые я не могу найти решение для

   NSURL *url2 = [NSURL URLWithString:@"www.google.com"];

    NSURLRequest *urlRequest = [NSURLRequest requestWithURL:url2];
    NSOperationQueue *queue = [[NSOperationQueue alloc] init];

    [NSURLConnection sendAsynchronousRequest:urlRequest queue:queue completionHandler:^(NSURLResponse *response, NSData *data, NSError *error)
    {
        if ([data length] > 0 && error == nil)
            [delegate receivedData:data];//i get the error here use of undeclared identifier 'delegate' ,when I put self insead I receive the error : no visible @interface for "my class name"  declares the selector "received data"
        else if ([data length] == 0 && error == nil)
            [delegate emptyReply];//same error here 
        else if (error != nil && error.code == ERROR_CODE_TIMEOUT) //the error here is "use of undelcared identifier ERROR_CODE_TIMEOUT
            [delegate timedOut];//error here is save as the first one
        else if (error != nil)
            [delegate downloadError:error];//error here is save as the first one
    }];

Я добавил NSURLConnectionDelegate в мой файл .h

Может кто-нибудь сказать мне, в чем ошибка?

Спасибо

Ответы [ 2 ]

1 голос
/ 29 марта 2012

У меня нет большого опыта работы с этим методом, но этот пример работает. Я отправил это на свой сервер, чтобы проверить получение информации о продукте для покупки в приложении. Вы можете добавить в него еще что-нибудь, чтобы, как вы разместили, проверить разные возможные результаты, но это должно помочь вам начать. Я не уверен, почему эта заглушка, которую вы опубликовали, имеет ссылки на делегата - смысл (или один из пунктов) блочных методов в том, чтобы иметь возможность делать такие вещи без делегата.

- (void)makeConnection {
NSURLRequest *theRequest=[NSURLRequest requestWithURL:[NSURL URLWithString:kServerPath]
                                          cachePolicy:NSURLRequestReloadIgnoringLocalCacheData
                                      timeoutInterval:5];
NSOperationQueue *queue = [[NSOperationQueue alloc] init];
[NSURLConnection sendAsynchronousRequest:theRequest queue:queue completionHandler:^(NSURLResponse* theResponse, NSData* theData, NSError* error) {
    NSLog(@"%@,  %@  %@",theResponse.suggestedFilename,theResponse.MIMEType,theResponse.textEncodingName);
    if (theData != nil && error == nil) {
        NSArray *productArray = [NSJSONSerialization JSONObjectWithData:theData options:NSJSONReadingMutableContainers error:nil];
        NSLog(@"%@",productArray);
    }else{
        NSLog(@"%@",error.localizedDescription);
    }
}];

}

0 голосов
/ 29 марта 2012

Я считаю, что это проще сделать - initWithRequest: Delegate: и реализовать методы делегата по мере необходимости.Вы будете хотеть

- (void)connection:(NSURLConnection *)theConnection didReceiveResponse:(NSURLResponse *)response

и

- (void)connection:(NSURLConnection *)theConnection didReceiveData:(NSData *)data

по крайней мере.См. http://developer.apple.com/library/ios/#samplecode/SimpleFTPSample/Listings/URLGetController_m.html для некоторого кода.Обратите внимание, что полученные данные вызываются для инкрементальных блоков.Вы, вероятно, хотите отслеживать общие данные в свойстве и добавлять данные по мере их поступления.Помимо этого, вы можете добавить обработку ошибок и аутентификацию, но это должно помочь вам начать.

...