我需要在服务器端解析上传的 XML 文档。现在我有一些在客户端工作的代码,但我想将它移到服务器端。我的客户端使用 FileReader API,其代码如下所示:
reader.onload = function (e) {
var InnerLibrary = new String(e.target.result);
if (window.DOMParser) {
parser = new DOMParser();
xmlDoc = parser.parseFromString(InnerLibrary, "text/xml");
console.log("start of xmlDoc console log");
console.log(xmlDoc);
console.log("end of xmlDoc console log");
$(xmlDoc).find('book').each(function () {
console.log("book Found");
console.log(($(this).attr("year")));
version = ($(this).attr("year"));
});
现在我被引导使用 libxmljs 来解决我现在似乎无法找到的其他一些 SO 问题。但是那个人说 libxmljs 会更好,因为这样我就可以使用 find() 遍历 XML DOM 对象,这暗示你不能在 xml2js 中这样做。
我试过 libxmljs 但出于某种原因,它导致我在这个问题中提到的问题在这里: The question where libxmljs causes problems
所以我想问,我可以在xml2js中使用这种遍历方法吗? (我的意思是,使用 .find() .each() .attr(),基本上这里使用的所有东西)
如果不是,我应该用什么方法找到数据?
更新: 我昨天尝试使用 xml2js,结果发现它无法将 xml 文件解析为字符串,它只会从字符串中解析出 xml。所以一个额外的问题是:
奖励:我可以在服务器端使用 FileReader API 吗?
最佳答案
由于您使用的是 jQuery 客户端,因此使用服务器端可能对您来说最方便。找到端口 here ,并且得到积极维护和使用(每天 1000 次下载)。请注意,默认情况下安装版本 1.8.3,但也支持高达 2.0.0 的版本。这是您指定要使用的版本的方式:
var jquery = require('jquery');
var $ = jquery(null, '1.8.3');
// or use 2.0.0
var $ = jquery(null, '2.0.0');
我还没有测试过 xml2js,但是自 find() , each() , 和 attr()都是 jQuery 函数,您还不如使用该功能来解析 DOM,因为您必须安装它才能使用这三个函数。如果您使用 npm install jquery 安装了该模块,那么您将如何使用它:
// create an instance of the library
var $ = require('jquery').create();
// use the same way as the browser
$(xml).find('book').each(function () {
console.log('book found');
console.log(($(this).attr("year")));
version = ($(this).attr("year"));
});
Node 也没有 FileReader API,因为已经有一个本地文件系统模块。 fs 可以执行所有文件 I/O带有 require('fs') 的库。
这是读取文件并将其传递给 jQuery 进行解析的方式:
var fs = require('fs');
var $ = require('jquery').create();
fs.readFile('/document.xml', function(err, data) {
if (err) throw err;
$(data).find('book').each(function () {
console.log('book found');
console.log(($(this).attr("year")));
var version = ($(this).attr("year"));
});
});
这也可以同步完成:
var fs = require('fs');
var $ = require('jquery').create();
var xml = fs.readFileSync('/document.xml');
$(xml).find('book').each(function () {
console.log('book found');
console.log(($(this).attr("year")));
var version = ($(this).attr("year"));
});
如果您不想使用 jQuery 的 Node 实现,您可以使用较低级别的 API,例如 jsdom和 htmlparser , 但您将无法使用您指定的三个功能。
编辑 在 jQuery 的 Node 实现中有一个 parseXML(),但它似乎不能正常工作。这是使用 xmldom 的替代解决方案:
var fs = require('fs');
var $ = require('jquery').create();
var DOMParser = require('xmldom').DOMParser;
var xml = fs.readFileSync('/document.xml');
var doc = DOMParser.parseFromString(xml, 'text/xml');
$(doc).find('book').each(function () {
console.log('book found');
console.log(($(this).attr("year")));
var version = ($(this).attr("year"));
});
关于javascript - 将 XML 解析移至服务器端,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18594765/
我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?
我正在尝试使用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请求没有正确的命名空间。任何人都可以建议我
我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我正在使用ruby1.9解析以下带有MacRoman字符的csv文件#encoding:ISO-8859-1#csv_parse.csvName,main-dialogue"Marceu","Giveittohimóhe,hiswife."我做了以下解析。require'csv'input_string=File.read("../csv_parse.rb").force_encoding("ISO-8859-1").encode("UTF-8")#=>"Name,main-dialogue\r\n\"Marceu\",\"Giveittohim\x97he,hiswife.\"\
我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为
最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru
在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo
我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b
您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除