草庐IT

protect_from_forgery

全部标签

ruby - 在 Ruby 中访问 protected 方法

我正在尝试在Ruby中为自己使用访问修饰符。我有:classPersondefinitialize(first_name,last_name,age)@first_name=first_name@last_name=last_name@age=ageenddefshow()puts@first_nameputs@last_nameputs@ageendprotecteddefcompare(other)self.instance_variable_get(:@age)other.instance_variable_get(:@age)endendp1=Person.new("Some"

ruby-on-rails - Rails ActiveRecord::StatementInvalid: PG::Error: ERROR: 缺少表的 FROM 子句条目

我有一个复杂的ActiveRecord查询,我正在根据用户的选择构建具有不同范围的查询。我正在使用2个gem,这似乎是有问题的,但我找不到谁是两者之间的罪魁祸首:Texticle(用于Postgresql完整搜索)(2.0.3)Squeel(用于ActiveRecord查询中的ruby​​语法)squeel(0.9.5)Arel或ActiveRecord本身这是我的类定义:classEvent"Entity",:foreign_key=>:entity_idbelongs_to:place,:class_name=>"Entity",:foreign_key=>:place_idcla

ruby-on-rails - 我们什么时候应该考虑使用 private 或 protected?

只是想知道,我们什么时候才真正必须对模型中的某些方法使用private或protected?有时我无法不在private或protected中对我的方法进行分组。我只是保持原样。但我知道这一定是一种不好的做法,否则这两个分组将不会在编程中创建。谢谢。 最佳答案 如果你打算在外部调用一个方法,record.method(),然后是“public”如果只在内部使用,self.method(),然后是“private”如果你计划在内部使用它,而且在后代中使用它,self.method()#insubclass,然后“protected”

ruby-on-rails - ActionController::InvalidAuthenticityToken Rails 5/Devise/Audited/PaperTrail gem

背景详情我正在使用Devise进行身份验证以登录到Rails5应用程序。每当我捆绑Audited或PaperTrailgem时,当我尝试#create一个新session时(通过登录表单-/users/sign_in),我收到以下错误:ActionController::InvalidAuthenticityToken环境详情ruby2.3.1gem:rails5.0.2设计=>4.2.1paper_trail=>7.0.1重现步骤:创建Rails5应用程序添加Devisegem添加经过审计或纸质记录的gem尝试登录 最佳答案 事实

ruby-on-rails - rails 3 : how to generate custom error message from failed validation

我正在使用validates:feed_id,presence:true,uniqueness:true我应该如何生成自定义错误消息以指定用户已经订阅了此提要(feed_id)字段重复我知道我可以只做validate_uniqueness_of但它会不必要地使代码困惑。如果唯一性验证失败,我该如何传递特定的错误消息?? 最佳答案 使用键message和期望的消息作为值而不是true放置一个散列:validates:feed_id,presence:true,uniqueness:{message:"alreadysubscribed

ruby-on-rails - rails 2 : test 'link_to' and other view helpers from the rails console?

在Rails2中,我经常使用控制台,并且想知道使用它测试View助手(例如“link_to”或“url_for”)的最佳方法是什么。执行此操作的最佳方法是什么? 最佳答案 您可以将您的includeActionView::Helpers::UrlHelper添加到~/.irbrc以在您启动控制台时自动加载它。 关于ruby-on-rails-rails2:test'link_to'andotherviewhelpersfromtherailsconsole?,我们在StackOverfl

ruby - 为什么不能使用要处理的符号调用 protected 方法?

给定以下类:classFoodefadup.tap{|foo|foo.bar}enddefbdup.tap(&:bar)endprotecteddefbarputs'bar'endend看起来Foo#a和Foo#b应该是等价的,但它们不是:>Foo.new.abar=>#>Foo.new.bNoMethodError:protectedmethod`bar'calledfor#这是有原因的吗?这是错误吗?在Ruby2.2.3p173上测试 最佳答案 让我们首先注意,在Ruby中,您可能知道,在类Foo上声明的方法a中,我可以在任何对

Ruby 动态类。如何修复 "warning: class variable access from toplevel"

我正在尝试编写一个程序,根据从文件中读取的配置动态定义ruby​​类。我知道我可以使用Class.new来做到这一点。这是一个示例程序:x=[1,2,3]Test=Class.newdo@@mylist=xdeffooputs@@mylistendendTest.new.foo当我运行它时,我得到以下输出(使用ruby​​1.9.3p0运行):c:/utils/test.rb:4:warning:classvariableaccessfromtoplevelc:/utils/test.rb:7:warning:classvariableaccessfromtoplevel123Does

ruby - 回应?和 protected 方法

respond_to可能不是那么明显?在ruby中工作。考虑一下:classAdefpublic_methodendprotecteddefprotected_methodendprivatedefprivate_methodendendobj=A.newobj.respond_to?(:public_method)#true-that'sprettyobviousobj.respond_to?(:private_method)#false-asexpectedobj.respond_to?(:protected_method)#true-WTF?因此,如果“obj”响应我们应该期望的

ruby-on-rails - 警告 : Can't mass-assign protected attributes

当发帖到/:username/about时,我收到“警告:无法批量分配protected属性:about”。classAbout["lower(username)=?",params[:username].downcase])iftrue@about=@user.aboutif@about.update_attributes(params[:about])flash[:notice]="Successfullyupdatedpost."respond_with(@about,:location=>about_path(@about.user.username))elseredirect