我想问一个关于 XML 文档根据其相应的 XML 模式进行验证的问题,如果您能帮助我,我将不胜感激。实际上,我才刚刚开始学习 XML 模式(我完全是初学者)。我购买了 Priscilla Walmsley 撰写的“Definitive XML Schema”一书(第 2 版),其中介绍了 XML Schema 1.1(我相信这是最新版本)。
现在的问题是,在本书的所有示例和练习中,架构文件的 namespace 和位置都是使用 Web URL 给出的。
这是本书的一个例子:
这是模式
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://datypic.com/prod"
xmlns:prod="http://datypic.com/prod">
<xs:element name="product" type="prod:ProductType"/>
<xs:complexType name="ProductType">
<xs:sequence>
<xs:element name="number" type="xs:integer"/>
<xs:element name="size" type="prod:SizeType"/>
</xs:sequence>
<xs:attribute name="effDate" type="xs:date"/>
</xs:complexType>
<xs:simpleType name="SizeType">
<xs:restriction base="xs:integer">
<xs:minInclusive value="2"/>
<xs:maxInclusive value="18"/>
</xs:restriction>
</xs:simpleType>
</xs:schema>
上面提到的要验证的 XML 内容是这个
<prod:product xmlns:prod="http://datypic.com/prod"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://datypic.com/prod prod.xsd"
effDate="2011-04-12">
<number>557</number>
<size>10</size>
</prod:product>
显然,[http://datypic.com/prod] 是作者维护的站点,因此我在阅读本书时无法在该站点上添加或删除任何文件以供练习。因此,我需要将 XML 和 XSD 文档都放在本地硬盘上(我使用的是 Linux Fedora Core 17 X86_64)。所以我所做的是将模式的内容放入名为“Example-01.xsd”的文件中,将 XML 内容放入名为“Example-01.xml”的文件中'。
我使用 Oracle PL/SQL 包 DBMS_XMLSCHEMA(企业版 11.2.0.1.0)首先注册模式,然后调用 XMLType 对象的验证方法以根据模式验证我的 XML 文档,类似于以下链接:
https://forums.oracle.com/forums/thread.jspa?messageID=2462207
我在 oracle 中创建了一个目录(通过 CREATE DIRECTORY)语句:
/home/train/Documents/myutl_file_dir/
我放置 XML 和 XSD 文档的位置。这正是我如何更改上述 XML 内容以便在本地引用 XSD
<prod:product xmlns:prod="http://datypic.com/prod"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://datypic.com/prod file:///home/train/Documents/myutl_file_dir/Example-01.xsd"
effDate="2011-04-12">
<number>557</number>
<size>10</size>
</prod:product>
因此,如果您将新的 XML 内容与上述示例进行比较,我唯一添加的内容是 file:///home/train/Documents/myutl_file_dir/Example-01.xsd,位于xsi:schemaLocation 值的末尾,以引用本地硬盘驱动器。我在这里找到了这个方法:
http://lists.w3.org/Archives/Public/xmlschema-dev/2001Dec/0161.html
现在,问题是它不起作用。当我运行我的脚本以通过调用 XMLType 对象的 schemaValidate() 方法来验证文档时,这里是 oracle 错误消息:
BEGIN
*
ERROR at line 1:
ORA-19030: Method invalid for non-schema based XML Documents.
ORA-06512: at "SYS.XMLTYPE", line 354
ORA-06512: at "TRAIN2012.ZXML_PKG", line 176
ORA-06512: at line 2
我从错误消息“Method invalid for non-schema based XML Documents”中了解到,oracle 只是简单地忽略了我为模式文件定义的文件路径,它认为没有为此 XML 文档声明的任何模式。
有什么想法吗?我该如何处理这个问题?
提前致谢
达里约什
最佳答案
好的,经过大量谷歌搜索并感谢 stefan nebesnak 的评论,我发现了导致错误的两个问题:
正如 Stefan 提到的,第一个是 DBMS_XMLSCHEMA.registerSchema 只能应用于基于模式的文档。最初我在我的 PL/SQL 代码中所做的是这样的:
l_xml_file_content := XMLType('Here I put the content of my XML document')
l_xml_file_content.schemaValidate();
正如您所看到的,在注册的模式和引用我的 XML 文档的 XMLType 对象之间绝对没有链接。我必须做的是:
l_xml_file_content :=
XMLType(
'Here I put the content of my XML document'
).createSchemaBasedXML('and here I put the very same schema URL used during registereation while I registered the schema by calling the DBMS_XMLSCHEMA.registerSchema method')
所以,第一个问题解决了,我的 XML 文档变成了基于模式的。
第二个问题是,在书中要根据模式验证的 XML 文档是按以下方式定义的:
<prod:product xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:prod="http://datypic.com/prod"
xsi:schemaLocation="http://datypic.com/prod prod.xsd"
effDate="2011-04-12">
<number>557</number>
<size>10</size>
</prod:product>
我从“xsi:schemaLocation="http://datypic.com/prod prod.xsd"”中了解到的是它的第一部分,即 http://datypic.com/prod指的是targetNameSpace,用空格隔开的第二部分,即prod.xsd 引用架构文档的位置(作为 URL),这是正确的。但我不知道的是,在 oracle DBMS_XMLSCHEMA 实现中,第二部分必须与通过调用 DBMS_XMLSCHEMA.RegisterSchema 方法注册模式所使用的 URL 完全相同,否则它将无法工作。这是确认这一点的 oracle 文档的链接:
http://docs.oracle.com/cd/B19306_01/appdev.102/b14259/xdb03usg.htm#BABBGBDA
If the target XML schema declares a target namespace, then the schemaLocation attribute is used to identify the XML schema. The value of this attribute is a pair of values separated by a space:
- the value of the target namespace declared in the XML schema
- the schema location hint, the unique identifier passed to procedure DBMS_XMLSCHEMA.registerSchema when the schema is registered with the database
而这正是我没有做的,我已经用“http://datypic.com/prod”注册了模式,只是因为在书中有一个文件名xsi:schemaLocation (prod.xsd) 的第二部分我认为我所要做的就是将模式内容放在一个名为 Example-01.xsd 的文件中,然后提供该文档的文件 URL,file:///home/train/Documents/myutl_file_dir/Example-01.xsd。这确实是一件愚蠢的事情,因为当您通过调用 DBMS_XMLSchema.registerSchema 向 oracle 注册模式时,oracle 会注册 XML 模式文档的内容。所以 oracle 需要的是在注册期间使用的 schemaURL,它允许查找和唯一标识特定的模式。这正是我的错误,我以为 oracle 正在寻找我的文件的物理位置。
结论:我已经通过 targetNameSpace 注册了模式:'http://datypic.com/prod'(好吧,这只是一个例子,我可以选择其他值)
所以,我的 XML 文档中 schemaLocation 的正确值是这样的:
xsi:schemaLocation="http://datypic.com/prod prod.xsd
http://datypic.com/prod prod.xsd"
这就解决了问题。
希望对遇到同样问题的小伙伴有所帮助。
问候,
达里约什
关于xml - Oracle 能否在本地文件系统上使用 XSD 模式验证 XML?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13223246/
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题