草庐IT

安全加密

全部标签

ruby-on-rails - Ruby/Rails 线程安全

我时常研究Ruby,但我没有用它做过任何大的或多线程的事情。我听说MRI只支持绿色线程,而JRuby通过JVM支持native线程。然而,我偶然发现博客和讨论组上的评论说“Rails不是线程安全的”或者Ruby本身不是线程安全的。例如有人评论说require语句有问题。这听起来有点基础。我见过很多不能正确处理并发的Java应用程序,我时不时地做噩梦:-)但至少你可以用Java编写线程安全的应用程序如果您真的知道自己在做什么(这并不容易)。这一切听起来很令人震惊,有人可以详细说明一下吗?到底是什么问题,如果是这种情况,Rails是如何设法工作的?我可以编写在没有竞争条件和死锁的情况下正常

ruby-on-rails - Ruby 中的 `try` 和 `&.`(安全导航运算符)有什么区别

这是我的代码:classOrder我以为&.是.try的快捷方式,但我想我错了。有人可以指出我所缺少的正确方向吗?感觉跟ruby无关。也许是葡萄?虽然我不明白这是怎么回事。 最佳答案 &.的工作方式类似于#try!,而不是#try。这里是#try!的描述(来自documentation):Sameas#try,butwillraiseaNoMethodErrorexceptionifthereceivingisnotnilanddoesnotimplementedthetriedmethod.所以基本上它可以避免在nil上调用方法,

ruby-on-rails - Ruby:使用私钥/公钥进行文件加密/解密

我正在寻找一种满足以下要求的文件加密/解密算法:算法必须可靠对于相当大的文件,算法应该很快可以通过一些参数(比如密码)生成私钥生成的私钥必须与公钥兼容(公钥只生成一次并存储在数据库中)是否有推荐算法的任何Ruby实现? 最佳答案 NoteWell:Asembossmentionsinthecomments,thisanswerisapoorfitforanactualsystem.Firstly,fileencryptionshouldnotbecarriedoutusingthismethod(ThelibprovidesAES,

ruby-on-rails - 可以安全删除 rails tmp/cache/assets 文件吗?

我似乎在命名为example的子文件夹中有很多它们sprockets%2F76920e6913c3390459175ac8e6dfd44a3它们似乎包含二进制数据。它们的用途是什么,为什么有这么多,最重要的是,可以安全地移除它们吗?他们需要永远的scp。 最佳答案 是的!您可以删除整个tmp目录,它将被重新创建。 关于ruby-on-rails-可以安全删除railstmp/cache/assets文件吗?,我们在StackOverflow上找到一个类似的问题:

ruby - Ruby 是否有 nil 值的安全导航运算符的语法,就像在 Groovy 中一样?

在Groovy中,有一个很好的语法来处理空值。例如,我可以做一个if语句:if(obj1?.obj2?.value){}这不会抛出NullPointerException,即使obj1为null(它的计算结果为false)。这是非常方便的东西,所以想知道是否有我错过的Ruby等价物。 最佳答案 在Rails应用程序中有Object#try所以你可以这样做obj1.try(:obj2).try(:value)或者用一个block(如下面的评论所述)obj.try{|obj|obj.value}更新在ruby​​2.3中有这样的运算符:

ruby-on-rails - 如何使用 OpenSSL::Cipher 加密 UTF-8 字符串中的数据?

在Rails3.0(Ruby1.9.2)应用程序中,我正在尝试使用如下方式加密一些数据:cipher=OpenSSL::Cipher.new'aes-256-cbc'cipher.encryptcipher.key=cipher.random_keycipher.iv=cipher.random_ivencrypted=cipher.update'mostsecretdataintheworld'encrypted这将进入UTF-8数据库。我的问题是>encrypted.encoding=>#>encrypted.encode'utf-8'Encoding::UndefinedConv

ruby - 无需外部 gem 的 Ruby 中的简单加密

我需要对一些文本字符串进行简单的加密。我想创建优惠券代码并使它们看起来很酷,因此随后创建的代码应该看起来非常不同。(除了看起来很酷之外,猜出密码也不是一件容易的事。)但我希望能够再次解密它们。所以算法必须是可逆的。我已经尝试过一些移动位的东西,所以它们看起来已经有点随机了。但是后续的两个代码(只有一点不同)当然看起来非常相似。有什么建议吗?我想在不使用外部gem的情况下做到这一点。菲利普 最佳答案 你可以使用OpenSSL::Cipher#formoreinfo,seehttp://ruby-doc.org/stdlib-1.9.3

ruby - nil 的安全导航运算符 (&.)

由于Ruby2.3引入了安全导航运算符(&.),也就是一个孤独的运算符,nil对象上的行为看起来很奇怪。nil.nil?#=>truenil&.nil?#=>nil它是设计成这样的吗?还是在添加独立运算符时遗漏了一些边缘案例? 最佳答案 foo&.bar是foo&&foo.bar的简写,那么您期望表达式nil&&nil.nil的结果是什么?是? 关于ruby-nil的安全导航运算符(&.),我们在StackOverflow上找到一个类似的问题: https:/

Ruby Hash .keys 和 .values,可以安全地采用相同的顺序吗?

基本的irb测试表明RubyHash以匹配顺序返回.keys和.values。假设是这种情况是否安全? 最佳答案 是的。根据RubyDocsforHash,"哈希按照插入相应键的顺序枚举它们的值。"因此,如果以相同的方式创建哈希,您应该始终获得相同的哈希顺序。 关于RubyHash.keys和.values,可以安全地采用相同的顺序吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/question

ruby - 如何安全地加入相对 url 段?

我正在尝试找到一种将部分url路径段连接在一起的可靠方法。有没有快速的方法来做到这一点?我尝试了以下方法:putsURI::join('resource/','/edit','12?option=test')我希望:resource/edit/12?option=test但是我得到了错误:`merge':bothURIarerelative(URI::BadURIError)我过去曾为此使用过File.join(),但将文件库用于url似乎有些不对。 最佳答案 URI的api不一定很好。URI::join仅当第一个作为带有协议(pr