我在正常的 HTTP 服务器上使用 Node 的基本 http.request() 函数没有问题。我需要对 SHOUTcast 服务器使用 http.request()(或类似的)。 SHOUTcast“协议(protocol)”与 HTTP 完全兼容,除了一个细节……第一响应行。
普通 HTTP 服务器响应:
HTTP/1.1 200 OK
SHOUTcast 服务器响应:
ICY 200 OK
同样,协议(protocol)的其余部分是相同的。唯一的区别是 HTTP/1.x 与 ICY。
我想扩展、子类化或以某种方式修改 Node 的 http.request() 函数,以便我可以使其与 SHOUTcast 服务器一起工作。使用 Node 连接到 SHOUTcast has been done before ,但只能通过重新发明整个轮子。我宁愿不这样做,因为协议(protocol)差异很小。
扩展或覆盖Node 的 HTTP 解析器的相关部分。 (我怀疑这是可能的,因为看起来是 the parser is native code 。)
创建我自己的代码来解析 HTTP 的相关部分,但尽可能多地为 HTTP 重用现有的 Node 组件。
创建一个简单的内部代理(或以某种方式中继数据),以便我可以在第一条服务器响应行到达 Node 的 HTTP 解析器之前对其进行修改。
还有别的吗?
我也考虑过使用 Shred ,但它不提供流式传输响应的选项。 (它在触发事件之前等待整个服务器响应完成,这不适用于数据可以无限期运行的流式服务器。)沿着同样的思路,我尝试了 Request ,但它使用 Node 自己的 HTTP 解析器,所以我得到了与使用 native HTTP 客户端时相同的解析错误。
最佳答案
我想出了另一种方法来做到这一点,类似于内部代理,但没有额外的连接。似乎可以为 HTTP 客户端覆盖内部使用的套接字。完成此操作后,在将数据传递给原始内部套接字 ondata 函数之前很容易 Hook 并修改数据。
var httpicy = new HttpIcyClient();
httpicy.request(/* your normal request parameters here */);
var http = require('http');
var HttpIcyClient = function () {};
HttpIcyClient.prototype.request = function (options, callback) {
var req = http.request(options, callback),
originalOnDataFunction,
receiveBuffer = new Buffer(0);
req.on('socket', function (socket) {
originalOnDataFunction = socket.ondata;
socket.ondata = function (d, start, end) {
receiveBuffer = Buffer.concat([receiveBuffer, d.slice(start, end)]);
if (receiveBuffer.length >= 4) {
socket.ondata = originalOnDataFunction;
if (receiveBuffer.toString('ascii', 0, 4) === 'ICY ') {
receiveBuffer = Buffer.concat([new Buffer('HTTP/1.0 ', 'ascii'), receiveBuffer.slice(4)]);
}
socket.ondata.apply(this, [receiveBuffer, 0, receiveBuffer.length]);
}
};
});
return req;
}
关于javascript - 覆盖 Node.js HTTP 解析器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9881305/
我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?
我主要使用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.\"\
我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah
我在pry中定义了一个函数:to_s,但我无法调用它。这个方法去哪里了,怎么调用?pry(main)>defto_spry(main)*'hello'pry(main)*endpry(main)>to_s=>"main"我的ruby版本是2.1.2看了一些答案和搜索后,我认为我得到了正确的答案:这个方法用在什么地方?在irb或pry中定义方法时,会转到Object.instance_methods[1]pry(main)>defto_s[1]pry(main)*'hello'[1]pry(main)*end=>:to_s[2]pry(main)>defhello[2]pry(main)
在Ruby类中,我重写了三个方法,并且在每个方法中,我基本上做同样的事情:classExampleClassdefconfirmation_required?is_allowed&&superenddefpostpone_email_change?is_allowed&&superenddefreconfirmation_required?is_allowed&&superendend有更简洁的语法吗?如何缩短代码? 最佳答案 如何使用别名?classExampleClassdefconfirmation_required?is_a
我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI
简而言之错误:NOTE:Gem::SourceIndex#add_specisdeprecated,useSpecification.add_spec.Itwillberemovedonorafter2011-11-01.Gem::SourceIndex#add_speccalledfrom/opt/local/lib/ruby/site_ruby/1.8/rubygems/source_index.rb:91./opt/local/lib/ruby/gems/1.8/gems/rails-2.3.8/lib/rails/gem_dependency.rb:275:in`==':und
我正在使用ruby2.1.0我有一个json文件。例如:test.json{"item":[{"apple":1},{"banana":2}]}用YAML.load加载这个文件安全吗?YAML.load(File.read('test.json'))我正在尝试加载一个json或yaml格式的文件。 最佳答案 YAML可以加载JSONYAML.load('{"something":"test","other":4}')=>{"something"=>"test","other"=>4}JSON将无法加载YAML。JSON.load("
假设您编写了一个类Sup,我决定将其扩展为SubSup。我不仅需要了解你发布的接口(interface),还需要了解你的私有(private)字段。见证这次失败:classSupdefinitialize@privateField="fromsup"enddefgetXreturn@privateFieldendendclassSub问题是,解决这个问题的正确方法是什么?看起来子类应该能够使用它想要的任何字段而不会弄乱父类(superclass)。编辑:equivalentexampleinJava返回"fromSup",这也是它应该产生的答案。 最佳答案