草庐IT

创建SQL函数(列Typex)

全部标签

ruby-on-rails - SQL 注入(inject)和 ActiveRecord

这对SQL注入(inject)安全吗:Guest.where(:event_id=>params[:id])我在发送params[:id]时没有进行任何类型的清理。一般来说,所有这些activerecord方法都安全吗?(如where、joins等。)如果不是,安全的最佳做法是什么?另外,是否有任何我应该注意的警告/边缘情况?谢谢 最佳答案 ActiveRecord的所有查询构建方法,如where、group、order等等,都可以安全地防止SQL注入(inject)ASLONGAS您不向它们传递原始SQL字符串。这容易受到SQL注

Ruby:如何更改函数调用中参数的值?

我将如何在ruby​​中实现一个函数,如下所示?change_me!(val)更新:我打算做的是:defchange_me!(val)val=val.chopwhileval.end_with?'#'orval.end_with?'/'end这刚刚结束......change_me!'test#///'=>"test#///" 最佳答案 您的想法是错误的。虽然可以在Ruby中执行此操作,但它会过于复杂。正确的做法是:val.change_me!当然,这取决于您要更改的类别。关键是,按照惯例,带有“!”的方法影响调用它们的类实例。所以

ruby-on-rails - 如何在 Rails 中创建对象数组?

我需要知道如何在Rails中创建对象数组以及如何向其中添加元素。我是ruby​​onrails的新手,这可能是个愚蠢的问题,但我找不到确切的答案。所以请专家给出一些关于这个的想法 最佳答案 你只需要一个数组:objArray=[]#or,ifyouwanttobeverboseobjArray=Array.new推送,push或使用:objArray.push17>>>[17]objArray>>[17,4]您可以使用任何您喜欢的对象,它不必是特定类型。 关于ruby-on-rails-

ruby - 如何在 Ruby 中动态创建局部变量?

我正在尝试使用eval在Ruby中动态创建局部变量并改变局部变量数组。我在IRB中这样做。eval"t=2"local_variables#=>[:_]eval"t"#=>NameError:undefinedlocalvariableormethod`t'formain:Objectlocal_variables[:_,:t]t#=>NameError:undefinedlocalvariableormethod`t'formain:Object 最佳答案 您必须使用相同的绑定(bind)对象同步评估。否则,单个评估有其自己的范围

sql - 在 AREL 中分组 ands 和 ors

我正在尝试使用arel查询此sql片段的等效项:WHERE(("participants"."accepted"='f'AND"participants"."contact_id"=1)OR"participants"."id"ISNULL)所以我想要(accepted&&contact_id=1)ORNULL这是我在AREL中得到的participants[:accepted].eq(false).and(participants[:contact_id].eq(1).or(participants[:id].is(nil)问题是,这会产生:("participants"."acce

ruby - 使用 block 创建哈希 (Ruby)

我可以从block创建Ruby哈希吗?像这样的东西(虽然这具体不起作用):foo=Hash.newdo|f|f[:apple]="red"f[:orange]="orange"f[:grape]="purple"end 最佳答案 在Ruby1.9中(或加载了ActiveSupport,例如在Rails中),您可以使用Object#tap,例如:foo=Hash.new.tapdo|bar|bar[:baz]='qux'end您可以将block传递给Hash.new,但这用于定义默认值:foo=Hash.new{|hsh,key|hs

ruby-on-rails - Has_Many :Through or :finder_sql

我已经确定了我想要的东西,但我似乎无法以Rails设计师正在寻找的方式获得它。基本上,我有(请搁置多元化/等问题):人类关系(parent、后代)我正在尝试获取单亲的所有后代,以及许多后代的单亲(假设每个后代只有一个parent)。我可以在模型中通过以下方式做到这一点:has_one:parent,:through=>:relationships,:foreign_key=>:human_id,:source=>:source_humanhas_many:offsprings,:finder_sql=>'SELECTDISTINCToffsprings.*'+'FROMhumansof

ruby - 在 Ruby 中动态创建类

我有一个应该看起来像这样的类:classFamily_Type1@people=Array.new(3)@people[0]=Policeman.new('Peter',0)@people[1]=Accountant.new('Paul',0)@people[2]=Policeman.new('Mary',0)definitialize(*ages)foriin0...@people.length@people[i].age=ages[i]endendend我希望能够在运行时定义一堆类似于这个的类(在启动时定义一次),其中数组的大小和分配给每个参数的类型在运行时从外部规范文件定义。我使

ruby - 如何测试使用 rspec 的 block 的函数

我有一个函数,它接受一个block,打开一个文件,产生并返回:defstart&block.....dosomestuffFile.open("filename","w")do|f|f.write("something")....dosomemorestuffyieldendend我正在尝试使用rspec为其编写测试。我如何stubFile.open以便它将对象f(由我提供)传递给block而不是尝试打开实际文件?像这样的东西:it"shouldtestsomething"domyobject=double("File",{'write'=>true})File.should_rece

ruby - 使用 Cucumber 或 RSpec+Selenium 创建最终用户文档?

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。关闭4年前。Improvethisquestion有没有人尝试从您的cucumber场景中创建最终用户(可能在线,可能打印)帮助/文档?或者使用RSpec和SeleniumRC的功能截取屏幕截图以用于文档?对于Cucumber,我想象的是这样的:Scenario:IfyouwanttoaddalinkGivenIamontheeditblogpostpageWhenIpressthe"addlink"buttonAn