Ruby使用REXML庫(kù)來(lái)解析xml格式數(shù)據(jù)的方法
REXML 是一個(gè)完全用ruby寫的processor ,他有多種api,其中兩個(gè)經(jīng)典的api是通過(guò)DOM-like 和SAX-like 來(lái)進(jìn)行區(qū)分的。第一種是將整個(gè)文件讀進(jìn)內(nèi)存,然后存儲(chǔ)為一個(gè)分層的形式(也就是一棵樹了).而第二種是"parse as you go",當(dāng)你的文件很大,并且內(nèi)存受到限制的時(shí)候,比較適合用這種。
rexml具有如下特點(diǎn):
- 100%用ruby編寫
- 可以用來(lái)解析SAX和DOM
- 輕量,不足2000行代碼
- 提供完整的API支持
- ruby中內(nèi)置
下面我們來(lái)看看如何使用它,假設(shè)我們有如下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, "http://movie") p movie XPath.each(xmldoc, "http://type") { |e| puts e.text } names = XPath.match(xmldoc, "http://format").map {|x| x.text } p names
以備不時(shí)之需!
PS:關(guān)于REXML的安全問題
Ruby官方網(wǎng)站在8月23日發(fā)布了安全通告:http://www.ruby-lang.org/en/news/2008/08/23/dos-vulnerability-in-rexml/,在Ruby當(dāng)前使用的XML解析庫(kù)REXML在解析具有嵌套遞歸元素的XML文件的時(shí)候,將會(huì)出現(xiàn)拒絕服務(wù)攻擊的缺陷,導(dǎo)致服務(wù)器資源耗盡!
凡是在Rails應(yīng)用程序當(dāng)中使用到了XML文件解析功能的都存在上述缺陷,需要進(jìn)行修復(fù)。在Rails當(dāng)中的修復(fù)辦法如下:
1、Rails2.0.2和以前的老版本
下載修復(fù)文件,拷貝到RAILS_ROOT/lib目錄下,并且在environment.rb當(dāng)中加入語(yǔ)句
require ‘rexml-expansion-fix'
2、Rails 2.1.0以上版本
下載修復(fù)文件,拷貝到RAILS_ROOT/config/initializers目錄下即可。
相關(guān)文章
Ruby實(shí)現(xiàn)批量對(duì)文件增加前綴代碼分享
這篇文章主要介紹了Ruby實(shí)現(xiàn)批量對(duì)文件增加前綴代碼分享,本文給出實(shí)現(xiàn)代碼、使用方法、使用示例等內(nèi)容,需要的朋友可以參考下2015-01-01使用Ruby實(shí)現(xiàn)簡(jiǎn)單的事物驅(qū)動(dòng)的web應(yīng)用的教程
這篇文章主要介紹了使用Ruby實(shí)現(xiàn)簡(jiǎn)單的事物驅(qū)動(dòng)的web應(yīng)用的教程,本文來(lái)自于IBM官方技術(shù)文檔,需要的朋友可以參考下2015-04-04Ruby中關(guān)于模塊的一些基礎(chǔ)知識(shí)
這篇文章主要介紹了Ruby中關(guān)于模塊的一些基礎(chǔ)知識(shí),是Ruby入門學(xué)習(xí)中的一些重要知識(shí)點(diǎn),需要的朋友可以參考下2015-07-07