Я боролся с этой проблемой уже несколько дней и думаю, что нашел ее ...
Я использую метод ASIHTTPRequest для подключения к моему php-скрипту, который вызывает запросы данных из базы данных,оттуда я инициирую делегаты NSXMLParser, кажется, что все работает нормально, я могу даже NSLog результаты, когда они анализируются, однако кажется, что, когда я пытаюсь поместить эти результаты в NSMutableArray, результаты, кажется, не хотят входить в него .. Япродолжайте получать нулевые значения ..
Я надеюсь, что кто-то может дать мне причину, почему вы можете указать мне направление, чтобы наконец решить эту проблему, потому что это становится настоящей болью позади ..
Это мой процесс синтаксического анализа
- (IBAction)setRequestString:(NSString *)string
{
//set up address
NSMutableString *databaseURL = [[NSMutableString alloc] initWithString:@"http://127.0.0.1:8888/CodeTest/"];
[databaseURL appendString:string];
//call delegates
NSURL *url = [NSURL URLWithString:databaseURL]; //LIVE mode
ASIFormDataRequest *request = [ASIFormDataRequest requestWithURL:url];
[request setDelegate:self];
[request startAsynchronous];
}
- (void)requestFinished:(ASIHTTPRequest *)request
{
NSString *responseString = [request responseString]; //Pass request text from server over to NSString
NSData *capturedResponseData = [responseString dataUsingEncoding:NSUTF8StringEncoding];
NSLog(@"%@", responseString);
[self startTheParsingProcess:capturedResponseData];
}
- (void)requestFailed:(ASIHTTPRequest *)request
{
NSError *error = [request error];
NSLog(@"%@", error);
}
#pragma mark - Parsing lifecycle
//--- Start parsing process using NSXMLParser ---------------->>
- (void)startTheParsingProcess:(NSData *)parserData
{
NSXMLParser *parser = [[NSXMLParser alloc] initWithData:parserData]; //incoming parserDatapassed to NSXMLParser delegate which starts parsing process
[parser setDelegate:self];
[parser parse]; //Starts the event-driven parsing operation.
[parser release];
[self.tableView reloadData];
}
- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
{
if ([elementName isEqual:@"item"]) {
// NSLog(@"Found title!");
itemString = [[NSMutableString alloc] init];
}
}
- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string
{
[itemString appendString:string];
}
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName
{
if ([elementName isEqual:@"item"]) {
//NSLog(@"ended title: %@", itemString);
[myDataArray addObject:itemString];
NSLog(@"%@", itemString);
NSLog(@"%@", myDataArray);
//TODO: Test release on memory consumption etc
[itemString release];
itemString = nil;
}
}
//--- Finish parsing process using NSXMLParser ---------------->>
Что печатает это
2011-09-08 08:46:24.424 iCode[1209:207] <?xml version="1.0"?>
<entries>
<item>Honda</item>
<item>Nissan</item>
<item>Mitsubishi</item>
<item>Toyota</item>
<item>Mazda</item>
</entries>
2011-09-08 08:46:24.426 iCode[1209:207] Honda
2011-09-08 08:46:24.426 iCode[1209:207] (null)
2011-09-08 08:46:24.427 iCode[1209:207] Nissan
2011-09-08 08:46:24.427 iCode[1209:207] (null)
2011-09-08 08:46:24.428 iCode[1209:207] Mitsubishi
2011-09-08 08:46:24.428 iCode[1209:207] (null)
2011-09-08 08:46:24.430 iCode[1209:207] Toyota
2011-09-08 08:46:24.431 iCode[1209:207] (null)
2011-09-08 08:46:24.431 iCode[1209:207] Mazda
2011-09-08 08:46:24.432 iCode[1209:207] (null)