草庐IT

消息安全

全部标签

ruby - 如何在安全的沙箱中运行不受信任的 Ruby 代码?

我希望能够运行不受信任的ruby​​代码。我希望能够将变量传递给它可能使用的所述不受信任的代码。我还希望上述代码将结果返回给我。这是我在想什么的概念性例子input="sweet"output=nilThread.start{$SAFE=4#...untrustedcodegoeshere,itusestheinputvariable(s)#tocalculatesomeresultthatitplacesintheoutputvariable}#parsetheoutputvariableasastring.澄清一下,我基本上是将不受信任的代码用作函数。我想要提供它的一些输入,然后允

ruby-on-rails - 设计在身份验证失败期间不显示错误消息?

当设计中发生身份验证失败时,我期待一个闪现通知。但是在身份验证失败期间什么也得不到,只是页面刷新并保持静止。我没有改变任何东西。默认设计安装本身不会显示带有无效身份验证尝试的闪存错误。我刚刚将devise作为gem安装并尝试使用它。甚至不要更改生成的代码中的一个字。可能我想是不是由于某些浏览器的可比性问题。但我得到其他手动引入的flash消息,其他工作。关于什么可能被破坏的任何建议。我正在使用rails3.0.1*更新*我收到用户注册(注册)失败消息,但没有收到登录失败消息。一些关于这个主题的谷歌搜索显示,对于注册它期望:-但是对于登录,它希望引用其他一些警报消息标签,但没有得到我必须

ruby-on-rails - 如何为 Puma 检查 Rails 应用程序的线程安全

我希望使用Puma网络服务器将我的Rails应用程序部署到Heroku。但是,我不太确定是否所有的Gem都是线程安全的。阅读所有Gems的源代码对我们来说不是可行的选择。有没有办法自动检查所有Gem的线程安全性?或者,如果执行/检测到线程不安全代码,Puma会提示/显示特定的错误日志吗? 最佳答案 一般检测不到线程安全。如果有某种方法可以自动检测到它,您的编译器/解释器可能会警告您。Raceconditions无法被自动系统检测到,它们甚至难以重现。取决于您的解释器:CRuby有GIL,所以使用Puma是没有意义的。如果您使用的是J

ruby - 在 RSpec 中指定对象不接收任何消息

我知道如何指定对象不应接收特定消息:expect(File).to_notreceive(:delete)我如何指定它根本不应该接收任何消息?有点像expect(File).to_notreceive_any_message 最佳答案 听起来你只是想用一个你没有定义期望的double替换有问题的对象(所以任何方法调用都会导致错误)。在你的具体情况下你可以做stub_const("File",double()) 关于ruby-在RSpec中指定对象不接收任何消息,我们在StackOverf

ruby - Rails3/ruby gem 中是否有将状态代码映射到消息的方法?

比如200=>Found403=>Notauthorized404=>Notfound我猜Rails3已经具有此功能,因为您可以将散列传递给render:status=>:not_found,我只是找不到以其他方式执行此操作的方法。如果没有,有人知道可以做到这一点的gem吗? 最佳答案 irb(main):001:0>Rack::Utils::HTTP_STATUS_CODES[200]=>"OK"irb(main):002:0>Rack::Utils::HTTP_STATUS_CODES[403]=>"Forbidden"irb(

ruby-on-rails - Ruby on Rails - 如何以彩色打印日志消息

我很惊讶我已经无法在SO上找到它了。我希望能够为输出到控制台的日志输出中的特定字符串段着色。所以像这样:"ThispartofthemessageinGreen:ThispartinBlue"可能是这样写的:Rails.logger.debug("ThispartofthemessageinGreen:".green+"ThispartinBlue".blue) 最佳答案 基本上,您要做的是将颜色的ANSI转义序列嵌入到调试字符串中,就像您在常规Ruby程序中所做的那样。有几种方法可以解决这个问题:使用rainbowgem,它允许你

ruby-on-rails - Rails 通知消息插件?

我正准备为我的Rails应用程序编写一些代码,不想重新发明轮子,因此我的问题是:你们知道任何Rails插件可以让应用程序显示特定于用户的通知消息,并允许用户将它们标记为“不再显示”吗?我的设想是显示一个顶部div(如StackOverflow最近添加的那个),以不同的颜色显示消息“标题”并且可以点击。单击后,它将弹出整个消息,然后允许用户对其进行标记以防止再次显示。那里有这样的东西吗?:-)到目前为止我发现了这两个插件:http://github.com/jstewart/system_messages/tree/masterhttp://github.com/arya/site_no

ruby - 使用 Hash#dig 或 Lonely operator(&.) 安全地为嵌套哈希赋值

h={data:{user:{value:"JohnDoe"}}}要为嵌套哈希赋值,我们可以使用h[:data][:user][:value]="Bob"但是如果中间的任何部分缺失,就会导致错误。有点像h.dig(:data,:user,:value)="Bob"不会工作,因为还没有可用的Hash#dig=。要安全地赋值,我们可以做h.dig(:data,:user)&.[]=(:value,"Bob")#orequivalentlyh.dig(:data,:user)&.store(:value,"Bob")但是有更好的方法吗? 最佳答案

ruby - Regexp.last_match 线程安全吗?

这是我正在查看的代码:defmethod_missing(id,*args)returnself.find(Regexp.last_match(1),args[0])ifid.id2name=~/find_by_(.+)/raiseNoMethodErrorend如果我有多个线程调用Regexp.last_match会怎样?如果我有多个线程使用method_missing方法调用对象会怎样? 最佳答案 Ruby1.9.2平台文档声明调用Regexp.last_match等同于读取特殊的$~全局变量。摘自“TheRubyProgram

ruby - 在 Ruby 中将 [] 与安全导航运算符一起使用

我目前有一段代码如下:ifmatch=request.path.match(/\A\/(?(?!admin|assets)\w+)/)match[:slug]end有没有办法使用安全导航运算符(在2.3.0中引入)来避免这种if条件? 最佳答案 只需使用普通(无糖)形式即可。request.path.match(/\A\/(?(?!admin|assets)\w+)/)&.[](:slug) 关于ruby-在Ruby中将[]与安全导航运算符一起使用,我们在StackOverflow上找到