Ruby使用REXML库来解析xml格式数据的方法

2023-12-05 0 729

REXML 是一个完全用ruby写的processor ,他有多种api,其中两个经典的api是通过DOM-like 和SAX-like 来进行区分的。第一种是将整个文件读进内存,然后存储为一个分层的形式(也就是一棵树了).而第二种是\”parse as you go\”,当你的文件很大,并且内存受到限制的时候,比较适合用这种。
rexml具有如下特点:

  • 100%用ruby编写
  • 可以用来解析SAX和DOM
  • 轻量,不足2000行代码
  • 提供完整的API支持
  • ruby中内置

下面我们来看看如何使用它,假设我们有如下xml文件:

<collection shelf=\”New Arrivals\”>
<movie title=\”Enemy Behind\”>
<type>War, Thriller</type>
<format>DVD</format>
<year>2003</year>
<rating>PG</rating>
<stars>10</stars>
<description>Talk about a US-Japan war</description>
</movie>
<movie title=\”Transformers\”>
<type>Anime, Science Fiction</type>
<format>DVD</format>
<year>1989</year>
<rating>R</rating>
<stars>8</stars>
<description>A schientific fiction</description>
</movie>
<movie title=\”Trigun\”>
<type>Anime, Action</type>
<format>DVD</format>
<episodes>4</episodes>
<rating>PG</rating>
<stars>10</stars>
<description>Vash the Stampede!</description>
</movie>
<movie title=\”Ishtar\”>
<type>Comedy</type>
<format>VHS</format>
<rating>PG</rating>
<stars>2</stars>
<description>Viewable boredom</description>
</movie>
</collection>

解析DOM:

require \’rexml/document\’
include REXML
xmlfile = File.new(\”movies.xml\”)
xmldoc = Document.new(xmlfile)
root = xmldoc.root
puts \”Root element : \” + root.attributes[\”shelf\”]
xmldoc.elements.each(\”collection/movie\”){
|e| puts \”Movie Title : \” + e.attributes[\”title\”]
}
xmldoc.elements.each(\”collection/movie/type\”) {
|e| puts \”Movie Type : \” + e.text
}
xmldoc.elements.each(\”collection/movie/description\”) {
|e| puts \”Movie Description : \” + e.text
}

使用XPATH:

require \’rexml/document\’
include REXML
xmlfile = File.new(\”movies.xml\”)
xmldoc = Document.new(xmlfile)
movie = XPath.first(xmldoc, \”//movie\”)
p movie
XPath.each(xmldoc, \”//type\”) { |e| puts e.text }
names = XPath.match(xmldoc, \”//format\”).map {|x| x.text }
p names

以备不时之需!

PS:关于REXML的安全问题
Ruby官方网站在8月23日发布了安全通告:http://www.ruby-lang.org/en/news/2008/08/23/dos-vulnerability-in-rexml/,在Ruby当前使用的XML解析库REXML在解析具有嵌套递归元素的XML文件的时候,将会出现拒绝服务攻击的缺陷,导致服务器资源耗尽!
凡是在Rails应用程序当中使用到了XML文件解析功能的都存在上述缺陷,需要进行修复。在Rails当中的修复办法如下:
1、Rails2.0.2和以前的老版本
下载修复文件,拷贝到RAILS_ROOT/lib目录下,并且在environment.rb当中加入语句

require ‘rexml-expansion-fix\’

2、Rails 2.1.0以上版本
下载修复文件,拷贝到RAILS_ROOT/config/initializers目录下即可。

您可能感兴趣的文章:

  • Ruby中使用Nokogiri包来操作XML格式数据的教程
  • Ruby中XML格式数据处理库REXML的使用方法指南
  • 实例解析Ruby程序中调用REXML来解析XML格式数据的用法
  • Ruby程序中创建和解析XML文件的方法
  • 在Ruby中处理XML和XSLT以及XPath的简单教程
  • Ruby的XML格式数据解析库Nokogiri的使用进阶

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

悠久资源 Ruby Ruby使用REXML库来解析xml格式数据的方法 https://www.u-9.cn/jiaoben/ruby/100788.html

常见问题

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务