网络之XML解析-原生

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介:

Json和XML都属于字符串,用于跨平台,前面总结了下Json,下面看下XML。

XML定义这些百度比我说的清,不再啰嗦,直接代码,我喜欢把东西都放进注释。

一、首先看下要解析的XML内容


<?xml version="1.0" encoding="utf-8"?>
<Users>
    <User id="1">
        <name>Tom</name>
        <age>20</age>
    </User>
    <User id="2">
        <name id = "222">John</name>
        <age>33</age>
    </User>
    <User>
        <name id = "333">Eric</name>
        <age>43</age>
    </User>
    <User>
        <name id = "444">Tony</name>
        <age>54</age>
    </User>
</Users>

 二、在项目中添加Person类为其添加属性


//
//  Person.h
//  XmlDemo
//
//  Created by City--Online on 15/4/29.
//  Copyright (c) 2015年 CYW. All rights reserved.
//
 
#import <Foundation/Foundation.h>
 
@interface Person : NSObject
 
@property(nonatomic,strong)NSString *Pid;
 
@property(nonatomic,strong)NSString *Name;
 
@property(nonatomic,assign)int Age;
@end

 三、用IOS原生框架来解析XML,注意实现代理


//
//  ViewController.m
//  XmlDemo
//
//  Created by City--Online on 15/4/29.
//  Copyright (c) 2015年 CYW. All rights reserved.
//
 
#import "ViewController.h"
#import "Person.h"
 
@interface ViewController () <NSXMLParserDelegate>
@property (nonatomic, strong) NSMutableArray *personArray;
@property (nonatomic, strong) NSMutableString *element;
 
@end
 
@implementation ViewController
 
- (void)viewDidLoad {
    [super viewDidLoad];
     
//    XML的解析方式有2种
//    DOM:一次性将整个XML文档加载进内存,比较适合解析小文件 文档驱动
//    SAX:从根元素开始,按顺序一个元素一个元素往下解析,比较适合解析大文件 事件驱动
     
    //IOS自带的属于SAX事件驱动的解析方式
//    就是一个事物模型解析,从头开始读取文档然后根据读取到的头标签,读完头标签后,理论上是读取标签值,然后读取后遇到结束标签等
    NSString *path=[[NSBundle mainBundle]pathForResource:@"user" ofType:@"xml"];
    NSURL *url=[[NSURL alloc]initFileURLWithPath:path];
    //实例化
    NSXMLParser *parser=[[NSXMLParser alloc]initWithContentsOfURL:url];
    //设置代理
    parser.delegate=self;
    //开始解析
    [parser parse];
    
}
// step1 开始解析
-(void)parserDidStartDocument:(NSXMLParser *)parser
{
    self.personArray = [[NSMutableArray alloc] initWithCapacity:0];
    self.element = [[NSMutableString alloc] init];
}
 
//step2 开始解析元素 获取头标签的信息<>里面的属性、名字
-(void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
{
    if ([elementName isEqualToString:@"Users"]) {
        NSLog(@"进入<Users>");
    }
    if ([elementName isEqualToString:@"User"]) {
         NSLog(@"进入<User>");
        Person *user = [[Person alloc] init];
        [_personArray addObject:user];
    }
    if ([elementName isEqualToString:@"name"]) {
        NSLog(@"进入<name>");
        Person *user = [_personArray objectAtIndex:[_personArray count] -1];
        user.Pid = [attributeDict objectForKey:@"id"];
    }
    if ([elementName isEqualToString:@"age"]) {
        NSLog(@"进入<age>");
    }
 
     
}
//step3 获得首尾标签间 > < 的内容
//此处分几种情况:
//1.当标签间内容为“”,如果</></>(如图</age></User></Users>)则进入step4,否则进入step2
//2.当标签间内容不为“”,则进入step4
- (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string
{
    NSLog(@"%@", string);
     
    //获取文本节点中的数据,因为下面的方法要保存这里获取的数据,所以要定义一个全局变量(可修改的字符串)
    //这里要赋值为空,目的是为了清空上一次的赋值
    [_element setString:@""];
    [_element appendString:string];//string是获取到的文本节点的值,只要是文本节点都会获取(包括换行),然后到下个方法中进行判断区分
}
//step4 标签解析结束</>
- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName
  namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName {
//    NSLog(@"%@", elementName);
    NSString *str=[[NSString alloc] initWithString:_element];
 
    if ([elementName isEqualToString:@"Users"]) {
        NSLog(@"</Users>= %@",str);
    }
    if ([elementName isEqualToString:@"name"]) {
        NSLog(@"</name>=%@",str);
        Person *user = [_personArray objectAtIndex:[_personArray count] -1];
        user.Name = str;
    }
    if ([elementName isEqualToString:@"age"]) {
        NSLog(@"</age>=%@",str);
        Person *user = [_personArray objectAtIndex:[_personArray count] -1];
        user.age = (int)[str integerValue];
    }
    if ([elementName isEqualToString:@"User"]) {
        NSLog(@"</User>=%@ ",str);
    }
}
//step5 解析结束
-(void)parserDidEndDocument:(NSXMLParser *)parser
{
    for (Person *p in self.personArray) {
        NSLog(@"%@  %d %@",p.Name,p.Age,p.Pid);
    }
}
//解析报错
-(void)parser:(NSXMLParser *)parser parseErrorOccurred:(NSError *)parseError
{
    NSLog(@"解析有误 Error:%@",parseError);
     
}
 
- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}
 
@end

 四、运行结果(显示的内容过长,减少了两个User)

在这里要感谢陈高oliver和袁伟(伟哥)


相关文章
|
1月前
|
安全 虚拟化
在数字化时代,网络项目的重要性日益凸显。本文从前期准备、方案内容和注意事项三个方面,详细解析了如何撰写一个优质高效的网络项目实施方案,帮助企业和用户实现更好的体验和竞争力
在数字化时代,网络项目的重要性日益凸显。本文从前期准备、方案内容和注意事项三个方面,详细解析了如何撰写一个优质高效的网络项目实施方案,帮助企业和用户实现更好的体验和竞争力。通过具体案例,展示了方案的制定和实施过程,强调了目标明确、技术先进、计划周密、风险可控和预算合理的重要性。
43 5
|
1月前
|
SQL 安全 网络安全
网络安全的护城河:漏洞防御与加密技术的深度解析
【10月更文挑战第37天】在数字时代的浪潮中,网络安全成为守护个人隐私与企业资产的坚固堡垒。本文将深入探讨网络安全的两大核心要素——安全漏洞和加密技术,以及如何通过提升安全意识来强化这道防线。文章旨在揭示网络攻防战的复杂性,并引导读者构建更为稳固的安全体系。
58 1
|
1月前
|
SQL 安全 测试技术
网络安全的盾牌与剑——漏洞防御与加密技术解析
【10月更文挑战第28天】 在数字时代的浪潮中,网络空间安全成为我们不可忽视的战场。本文将深入探讨网络安全的核心问题,包括常见的网络安全漏洞、先进的加密技术以及提升个人和组织的安全意识。通过实际案例分析和代码示例,我们将揭示黑客如何利用漏洞进行攻击,展示如何使用加密技术保护数据,并强调培养网络安全意识的重要性。让我们一同揭开网络安全的神秘面纱,为打造更加坚固的数字防线做好准备。
43 3
|
18天前
|
机器学习/深度学习 人工智能 算法
深入解析图神经网络:Graph Transformer的算法基础与工程实践
Graph Transformer是一种结合了Transformer自注意力机制与图神经网络(GNNs)特点的神经网络模型,专为处理图结构数据而设计。它通过改进的数据表示方法、自注意力机制、拉普拉斯位置编码、消息传递与聚合机制等核心技术,实现了对图中节点间关系信息的高效处理及长程依赖关系的捕捉,显著提升了图相关任务的性能。本文详细解析了Graph Transformer的技术原理、实现细节及应用场景,并通过图书推荐系统的实例,展示了其在实际问题解决中的强大能力。
114 30
|
2天前
|
网络协议
TCP报文格式全解析:网络小白变高手的必读指南
本文深入解析TCP报文格式,涵盖源端口、目的端口、序号、确认序号、首部长度、标志字段、窗口大小、检验和、紧急指针及选项字段。每个字段的作用和意义详尽说明,帮助理解TCP协议如何确保可靠的数据传输,是互联网通信的基石。通过学习这些内容,读者可以更好地掌握TCP的工作原理及其在网络中的应用。
|
2天前
|
存储 监控 网络协议
一次读懂网络分层:应用层到物理层全解析
网络模型分为五层结构,从应用层到物理层逐层解析。应用层提供HTTP、SMTP、DNS等常见协议;传输层通过TCP和UDP确保数据可靠或高效传输;网络层利用IP和路由器实现跨网数据包路由;数据链路层通过MAC地址管理局域网设备;物理层负责比特流的物理传输。各层协同工作,使网络通信得以实现。
|
2天前
|
网络协议 安全 网络安全
探索网络模型与协议:从OSI到HTTPs的原理解析
OSI七层网络模型和TCP/IP四层模型是理解和设计计算机网络的框架。OSI模型包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,而TCP/IP模型则简化为链路层、网络层、传输层和 HTTPS协议基于HTTP并通过TLS/SSL加密数据,确保安全传输。其连接过程涉及TCP三次握手、SSL证书验证、对称密钥交换等步骤,以保障通信的安全性和完整性。数字信封技术使用非对称加密和数字证书确保数据的机密性和身份认证。 浏览器通过Https访问网站的过程包括输入网址、DNS解析、建立TCP连接、发送HTTPS请求、接收响应、验证证书和解析网页内容等步骤,确保用户与服务器之间的安全通信。
17 1
|
23天前
|
SQL 安全 算法
网络安全之盾:漏洞防御与加密技术解析
在数字时代的浪潮中,网络安全和信息安全成为维护个人隐私和企业资产的重要防线。本文将深入探讨网络安全的薄弱环节—漏洞,并分析如何通过加密技术来加固这道防线。文章还将分享提升安全意识的重要性,以预防潜在的网络威胁,确保数据的安全与隐私。
45 2
|
25天前
|
安全 算法 网络安全
网络安全的盾牌与剑:漏洞防御与加密技术深度解析
在数字信息的海洋中,网络安全是航行者不可或缺的指南针。本文将深入探讨网络安全的两大支柱——漏洞防御和加密技术,揭示它们如何共同构筑起信息时代的安全屏障。从最新的网络攻击手段到防御策略,再到加密技术的奥秘,我们将一起揭开网络安全的神秘面纱,理解其背后的科学原理,并掌握保护个人和企业数据的关键技能。
29 3
|
27天前
|
网络协议
网络通信的基石:TCP/IP协议栈的层次结构解析
在现代网络通信中,TCP/IP协议栈是构建互联网的基础。它定义了数据如何在网络中传输,以及如何确保数据的完整性和可靠性。本文将深入探讨TCP/IP协议栈的层次结构,揭示每一层的功能和重要性。
54 5

推荐镜像

更多