草庐IT

公众号支持RSS订阅

全部标签

ruby - AMQP 动态创建订阅队列

我正在尝试使用AMQP、Websockets和Ruby构建一个简单的聊天应用程序。我知道这可能不是理解AMQP的最佳用例,但我想了解我哪里出错了。以下是我的amqp-server代码require'rubygems'require'amqp'require'mongo'require'em-websocket'require'json'classMessageParser#messageformat=>"room:harry_potter,nickname:siddharth,room:members"defself.parse(message)parsed_message=JSON.

支持 WikiWord 的 ruby​​ markdown 解析器?

我正在使用git-wiki用于我的个人笔记存储。它工作得很好,除了WikiWords在markdown解析阶段之前使用正则表达式转换为链接。这会弄乱很多东西,例如指向外部wiki页面的链接或block引号(如果我要引用某些内容,我不希望将WikiWord更改为链接)。是否有能够理解WikiLinks的基于ruby​​的Markdown解析器? 最佳答案 最好的解析器是基于C的解析器(upskirt/sundown),它的ruby​​迭代是红地毯:https://github.com/tanoku/redcarpet出于性能和安全原因

iphone - 扩展 restful_authentication/AuthLogic 以支持匿名 iPhone 的延迟登录的最佳方法是什么?

我正在构建一个与RubyonRails后端对话的iPhone应用程序。RubyonRails应用程序还将为Web用户提供服务。restful_authentication插件是提供快速和可定制的用户身份验证的绝佳方式。但是,我希望iPhone应用程序的用户在新列中存储一个由手机的唯一标识符([[UIDevicedevice]uniqueIdentifier])自动创建的帐户。稍后,当用户准备好创建用户名/密码时,帐户将更新为包含用户名和密码,iPhone唯一标识符保持不变。用户在设置用户名/密码之前不能访问该网站。然而,他们可以使用iPhone应用程序,因为该应用程序可以使用它的标识符

ruby - 使用 Ruby 解析标签中有冒号的 RSS 项?

我正在尝试从具有此标记结构的RSS提要中解析信息:foobar使用内置的RubyRSS库。显然,执行item.dc:subject会引发错误,但我想不出任何方法来提取该信息。有什么办法可以让它工作吗?或者是否可以使用不同的RSS库? 最佳答案 带有“:”的标签实际上是带有命名空间的XML标签。我使用RSS模块从来没有取得过好的结果,因为提要格式通常不符合规范,导致模块放弃。我强烈推荐使用Nokogiri来解析提要,无论是RDF、RSS还是ATOM。Nokogiri能够使用XPath访问器或CSS访问器,并且都支持命名空间。最后两行是

ruby - Net::HTTP 中的服务器名称指示支持?

我正在尝试让Ruby的Net::HTTP实现与SNI一起工作。mail.google.com和gmail.com都位于同一个IP地址上,因此当通过SSL连接时,Google服务器需要知道要使用哪个证书。默认情况下,它会返回mail.google.com证书,如果您尝试实现WebFinger,这就是一个问题。WebFinger要求您检索https://gmail.com/.well-known/host-meta以获取LRDD信息,但是,出于安全原因,验证SSL证书至关重要信息。由于Google在这种情况下提供默认的mail.google.com证书,因此SSLpost_connecti

ruby - 哪些 Ruby 类支持 .clone?

Ruby在Object中定义了#clone。令我惊讶的是,有些类在调用它时会引发异常。我发现NilClass、TrueClass、FalseClass、Fixnum有这种行为。1)是否存在不允许#clone的完整类列表(至少是核心类)?或者有没有办法检测特定类是否支持#clone?2)42.clone有什么问题? 最佳答案 我认为没有正式的列表,至少除非你算上阅读源代码。原因2)不起作用是因为对Fixnums应用了优化。它们在内部存储/传递为它们的实际值(true、false和nil也是如此),而不是作为指针。天真的解决方案是让42

ruby - 订阅一个队列,收到1条消息,然后取消订阅

我有一个场景,我需要极快地分发和处理作业。我将在队列中快速填充大约45个作业,我可以同时处理大约20个(5台机器,每台机器4个内核)。每项工作花费的时间长短不一,而且垃圾收集使事情变得复杂,因此我需要能够让消费者离线以进行垃圾收集。目前,我的一切都与pop一起工作(每个消费者每5毫秒弹出一次)。这似乎是不可取的,因为它转换为每秒600个pop请求到rabbitmq。如果有一个类似于订阅的pop命令,但只针对一条消息,我会很高兴。(进程会阻塞,等待来自rabbitMQ连接的输入,通过类似于Kernel.select的东西)我试图欺骗AMQPgem做这样的事情,但它不起作用:我似乎无法取消

ruby-on-rails - 在 ruby​​ 中支持两种语法的问题

我有一种情况需要这样调用:classOfficeattr_accessor:workers,:iddefinitialize@workers=[]enddefworkersworkertype=worker.typeresp=Worker.post("/office/#{@id}/workers.json",:worker=>{:type=>type})worker=Worker.new()resp.to_hash.each_pairdo|k,v|worker.send("#{k}=",v)ifworker.respond_to?(k)endself.workersworker类(Cl

ruby-on-rails - 在 ruby​​ 中支持 IMAP IDLE

好吧,几个小时以来我一直很厌烦它。我以为ruby​​1.9的net/imap.rb支持空闲命令,但现在还没有。谁能帮我实现它?来自here,我认为这可行:classNet::IMAPdefidlecmd="IDLE"synchronizedotag=generate_tagput_string(tag+""+cmd)put_string(CRLF)endenddefdonecmd="DONE"synchronizedoput_string(cmd)put_string(CRLF)endendend但是imap.idle只返回nil。 最佳答案

ruby - ActiveJob::SerializationError - 不支持的参数类型:Time/DateTime

我正在使用Rails5和ActiveJob来处理后台任务。我正在尝试将使用as_json序列化的对象传递给我的工作,但我收到以下错误:ActiveJob::SerializationError(Unsupportedargumenttype:Time):ActiveJob::SerializationError(Unsupportedargumenttype:DateTime):我知道ActiveJob不会接受Time/DateTime对象,因为一些排队系统不处理这些类型。所以我要序列化的对象如下:card=Card.first=>#当我运行时:card.as_json=>{"id"=