草庐IT

安全模块

全部标签

ruby - 使用安全转换验证使用 Ruby/OpenSSL 创建的 RSA 签名

我正在尝试为我的应用程序实现一个简单的许可key方案,但我遇到了重大障碍。我正在按照OpenSSLforLicenseKeys中的示例进行操作.自从该博文写于2004年并且OpenSSL在OSX上已被弃用后,我尝试使用SecurityTransformsAPI代替OpenSSL来完成许可证key验证。但是,我正在使用OpenSSL生成私钥和公钥;许可证key由Ruby网络应用程序使用私钥生成,该应用程序使用来自购买者电子邮件地址的SHA-256摘要的RubyOpenSSL包装器库。问题是,我所做的任何事情似乎都无法使用安全转换API验证的OpenSSL从Ruby生成签名。我正在处理的R

arrays - 从每个数组中删除是否安全?

是否可以在通过each遍历Array时安全地删除元素?第一个测试看起来很有希望:a=(1..4).to_aa.each{|i|a.delete(i)ifi==2}#=>[1,3,4]但是,我找不到确凿的事实:是否安全(设计)从哪个Ruby版本开始它是安全的在过去的某些时候,它似乎是notpossibletodo:It'snotworkingbecauseRubyexitsthe.eachloopwhenattemptingtodeletesomething.documentation没有说明迭代期间的可删除性。我不是在寻找reject或delete_if。我想对数组的元素做一些事情,有

ruby - 在类中包含模块并执行代码

这是我以前上过的课classSomething#Definesthevalidatesclassmethods,whichiscalleduponinstantiationincludeModulevalidates:namevalidates:dateend我现在有几个使用相同功能的对象,更糟糕的是,有几个定义相似事物的对象,如下所示:classAnotherthing#Definesthevalidatesclassmethods,whichiscalleduponinstantiationincludeModulevalidates:ageend我想“重用”这些类的内容,所以我把

ruby - 引用与类同名的模块中的方法

我有一个同名的类和一个模块:modulePushoverdefconfigure..endendmoduleMyModuleclassPushoverdefblahPushover.configureendendend这不起作用,因为Pushover.configure调用指向包含类。现在,一个明显的解决方法是重命名该类。但是,模块来自gem,并且类符合DSL中要求的命名约定。所以理想情况下,它们应该保持不变。我还可以创建第二个帮助程序类并通过它进行调用,但这一切看起来有点老套。我的首选解决方案是直接引用模块方法。围绕这个领域的所有现有问题似乎都在相反的方向上消除歧义——即他们想要获得

ruby-on-rails - 模块的 Rails 未定义方法

在Rails中,如何使用模块中的特定方法。例如,#./app/controllers/my_controller.rbclassMyControllerMyController包含MyModule。在action中,我想使用MyModule.a_method(请注意我在MyController中也有一个私有(private)的a_method并且我不我想用这个。)我尝试过的事情:1)将模块中的方法定义为self.defself.a_methodend2)在Controller中使用::表示法(MyModule::a_method)我不断收到的错误是MyModule:module的未定义

ruby - 如何改进 Ruby 中的模块方法?

您可以使用优化您的类(class)moduleRefinedStringrefineStringdodefto_boolean(text)!!(text=~/^(true|t|yes|y|1)$/i)endendend但是如何细化模块方法呢?这:moduleRefinedMathrefineMathdodefPI22/7endendend引发:TypeError:错误的参数类型模块(预期类) 最佳答案 这段代码可以工作:moduleMathdefself.piputs'originalmethod'endendmoduleRefin

ruby - 为什么 Ruby 使用自己的安全导航运算符语法?

Ruby2.3.0引入了安全导航语法,它通过引入一个新的运算符来简化链式方法调用的nil处理,该运算符仅在先前语句的值不是nil。这是一个已经存在于C#、Groovy和Swift中的特性。例如inGroovy,语法是foo?.bar这基本上意味着结果值是foo.bar除非foo是null,在这种情况下返回值也是null因此不会抛出异常。还有C#(称为空条件运算符)和Swift(称为可选链接表达式)使用此表示法。所以语法在其他语言中似乎是相当标准的。现在,为什么在Ruby中语法是foo&.bar代替? 最佳答案 此答案基于thedis

ruby-on-rails - Ruby on Rails 源代码安全/混淆

这个问题在这里已经有了答案:EncodingRubyonRailscode?(5个答案)关闭3年前。我刚刚开始使用RubyonRails开发,我有一个关于源代码“隐私”的问题。据我所知(我还没有做过部署,只是在本地开发环境中使用了RoR),当部署RoR应用程序时,所有源代码都是“可见的”"在服务器上?我怎样才能保护我的代码;可以这么说?我所说的保护是指,主要目的是某人(例如RoR提供商的服务器管理员)无法通过轻松找出代码中“摆弄”的位置来“破坏”代码与”。Shopify、Yellowpages等使用RoR的网站如何确保其代码未被“破坏”?更新我真正要寻找的是,假设如果我有一些进行信用卡

ruby - 在 Ruby 的类中访问模块的类变量

我有一个包含类变量的模块moduleAbc@@variable="huhu"defself.get_variable@@variableendclassHellodefholaputsAbc.get_variableendendenda=Abc::Hello.newa.hola是否可以在Hello中获取@@variable而无需使用get_variable方法?我的意思是像Abc.variable这样的东西会很好。只是好奇。 最佳答案 您不能在模块的Hello类范围内直接访问@@variable(即Abc.variable)>Abc

ruby - 如何在 ruby​​ 中组合包含 method_missing 的模块

我有几个模块缺少扩展方法:moduleSaysHellodefrespond_to?(method)super.respond_to?(method)||!!(method.to_s=~/^hello/)enddefmethod_missing(method,*args,&block)if(method.to_s=~/^hello/)puts"Hello,#{method}"elsesuper.method_missing(method,*args,&block)endendendmoduleSaysGoodbyedefrespond_to?(method)super.respond_