草庐IT

数据安全运维

全部标签

ruby-on-rails - 迁移数据 - 不仅仅是模式,Rails

有时,需要数据迁移。随着时间的推移,使用域模型的代码更改和迁移不再有效,并且迁移失败。迁移数据的最佳做法是什么?我试着举个例子来说明问题:考虑一下。你有一个迁移classChangeFromPartnerAppliedToAppliedAt当然,这运行得非常好。稍后,您需要更改架构classAddAcceptanceConfirmedAt对你来说,没问题。它运行完美。但是,如果您的同事今天拉取了这两个,还没有运行第一次迁移,他将在运行第一次迁移时遇到此错误:rakeaborted!Anerrorhasoccurred,thisandalllatermigrationscanceled:

ruby - 如何在 Rails 之外的 Ruby 项目上加载 ActiveRecord 数据库任务?

事件记录3.2.14我想在非RailsRuby项目中使用ActiveRecord。我想让ActiveRecord定义的rake任务可用。我该怎么做?rakedb:create#CreatethedatabasefromDATABASE_URLorconfig/database.ymlforthecurrentRails.env(usedb:create:alltocreatealldbsintheconfig)rakedb:drop#DropsthedatabaseusingDATABASE_URLorthecurrentRails.env(usedb:drop:alltodropal

ruby - 如何在不保存到文件的情况下将文本数据从 ruby​​ 控制台传递到剪贴板?

我正在尝试将我创建的全局变量中包含的数组传递到我mac上的剪贴板中。它很长,所以我不想在我的控制台上突出显示、复制和粘贴。我想使用嵌入式unix代码,特别是mac笔记本电脑控制台的pbcopy函数,它允许我将文本传递到我的计算机剪贴板,准备粘贴。如果我通过文件保存来做到这一点,我会做这样的事情(在ruby​​中):stringdata=>File.open("temp.txt"){|f|f.write(stringdata)}`cattemp.txt|pbcopy`但我是否可以在不创建临时文件的情况下执行此操作?我相信这是可能的。文本中的所有内容都是可能的。提前感谢您的解决方案

ruby - 哪个查询去了哪个数据库的 ActiveRecord 日志

在与不同数据库有多个连接的ActiveRecord应用程序中,日志中没有任何内容表明哪个查询去了哪个数据库。这些查询分离数据库:Base1.connection.select_value("select*fromfoo")Base2.connection.select_value("select*fromfoo")发出这些日志条目:D,[2017-03-13T09:27:11.844395#22112]DEBUG--:(0.6ms)select*fromfooD,[2017-03-13T09:27:11.844539#22112]DEBUG--:(0.1ms)select*fromfo

ruby - 自动加载在 Ruby 1.9 中是线程安全的吗?

在我看来,自从thisfamousthread以来,Ruby社区一直对自动加载感到恐惧。,出于线程安全原因,不鼓励使用它。有谁知道这在Ruby1.9.1或1.9.2中是否不再是一个问题?我已经看到一些关于在互斥体中包装要求等的讨论,但是1.9变更日志(或者至少是我能够找到的那么多)似乎没有解决这个特定问题。我想知道我是否可以合理地开始在1.9-only库中自动加载而不会有任何合理的悲伤。提前感谢您的任何见解。 最佳答案 因为我也对此感到好奇,所以在2011年对此进行了更新。目前打开了两张工单:http://redmine.ruby-

ruby-on-rails - 为 Rails 迁移加载种子数据

我有一个现有的数据库,我正在将以前的“NULL”列转换为具有默认值的列(并使用所述默认值填充该列)。但是,该值是我需要创建的记录的ID。如果我将此记录放入db/seeds.rb,它不会运行,因为db/seeds.rb在迁移之后运行——但迁移需要种子数据。如果我在迁移中保留记录创建,那么如果我使用db:load创建新数据库,我将不会获得记录。除了在db/seeds.rb和迁移中复制它之外,还有更好的方法吗?谢谢! 最佳答案 虽然我能理解您希望保持DRY并且不必在migration和seeds.rb中都写这个,但我认为您应该在两个地方都

ruby-on-rails - 多个数据库的测试和 database_cleaner

我们有一个邮箱模型,它使用另一个邮件应用程序也连接到的辅助数据库。这称为使用establish_connection:mail_database现在,我想我可以尝试将它包装在if语句中,以便它为测试环境使用不同的连接,但我想知道如何保持这个数据库的清洁,最好使用我们已经将其用于“常规”数据库的database_cleaner。我希望有人能将我推向正确的方向。 最佳答案 我有一个使用rspec(2.12.0)和使用database_cleaner(0.9.1f4b44bb)测试的rails3.2.10应用程序,它有两个用于mysql的

ruby-on-rails - 为什么对 params 哈希进行切片会对批量分配造成安全问题?

通过批量分配防止安全风险的官方方法是使用attr_accessible.然而,一些程序员认为这不是模型的工作(或者至少不是仅模型的工作)。在Controller中执行此操作的最简单方法是对params哈希进行切片:@user=User.update_attributes(params[:user].slice(:name))但是文档指出:NotethatusingHash#exceptorHash#sliceinplaceofattr_accessibletosanitizeattributeswon’tprovidesufficientprotection.这是为什么呢?为什么par

ruby-on-rails - 没有数据库的注册或邀请电子邮件验证

我想让我的数据库中几乎没有陈旧的帐户,我正在考虑进行新的注册和邀请,将他们的数据作为加密或散列url放入欢迎电子邮件中。一旦访问url中的链接,信息就会作为帐户添加到数据库中。目前有什么东西可以做到这一点吗?关于以这种方式进行用户注册的任何引用、想法或警告?谢谢!编辑:我做了一个工作示例,url是127个字符。http://localhost/confirm?_=hBRCGVqie5PetQhjiagq9F6kmi7luVxpcpEYMWaxrtSHIPA3rF0Hufy6EgiH%0A%2BL3t9dcgV9es9Zywkl4F1lcMyA%3D%3D%0A显然,更多数据=更大的ur

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

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