我有一个Web服务,对DataBase进行了不同的更改。当我使用带有sql标签的webservice返回行时,如下所示:
<sql>
DELETE FROM TABLE WHERE ...
</sql>
<sql>
INSERT INTO TABLE WHERE ...
</sql>
<sql>
UPDATE TABLE SET ... WHERE ...
</sql>
我将这些代码保存在NSMutableArray中,如下所示:
-(void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName {
if ([elementName isEqualToString:@"sql"]){
[maResultado addObject:[NSMutableString stringWithFormat:@"%@", ResultadoSoap]];
[ResultadoSoap setString:@""];
}
}
这很好,但是如果webservice返回带有重音的单词(重音因为是西班牙语),应用程序只会在重音后获得短语。 例: Web服务返回:
<sql>
INSERT INTO DATOS(datos, fecha) VALUES('Indagar si el médico a tenido oportunidad de ...', '20/02/2013')
</sql>
我这样做:
if ([elementName isEqualToString:@"sql"]){
[maResultado addObject:[NSMutableString stringWithFormat:@"%@", ResultadoSoap]];
[ResultadoSoap setString:@""];
}
并且在objectatindex的maResultado中只有这个:
édico a tenido oportunidad de ...', '20/02/2013')
答案 0 :(得分:2)
对于XML元素,可以多次调用parser:foundCharacters:
委托函数。如果字符内容包含特殊字符,则会发生这种情况。在您的情况下,对于数据
<sql>
INSERT INTO DATOS(datos, fecha) VALUES('Indagar si el médico a tenido oportunidad de ...', '20/02/2013')
</sql>
委托函数被调用两次,首先是字符串
INSERT INTO DATOS(datos, fecha) VALUES('Indagar si el m
然后再使用字符串
édico a tenido oportunidad de ...', '20/02/2013')
因此,您必须将parser:foundCharacters:
中的字符串附加到当前字符串,例如
- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string
{
[currentElementValue appendString:string];
}