草庐IT

annotate_admin_settings_submit

全部标签

ruby-on-rails - Rails(set_no_cache 方法)无法在 Safari 和 Opera 中禁用浏览器缓存

在使用Devise进行身份验证后,我发现其中存在一个安全漏洞,在用户注销后,session变量会被保留。这允许任何人按下后退按钮并访问已登录用户的上一个屏幕。我看了这些帖子Num1Num2Num3我将这些行添加到我的application_controllerbefore_filter:set_no_cachedefset_no_cacheresponse.headers["Cache-Control"]="no-cache,no-store,max-age=0,must-revalidate"response.headers["Pragma"]="no-cache"response.

ruby - 在类声明后设置类继承或在 const_set 类上设置类继承

如果之前已经定义了一个类,我如何告诉它从父类继承例如:classParent..endclassKlass..end现在我希望它继承自Parent我无法重新打开类并设置它,因为我会收到类不匹配错误classKlass具体来说,我试图找出如何在我通过Object.const_set创建的类上设置类继承klass=Object.const_set('Klass',Class.new)如何让Klass继承自Parent类? 最佳答案 无法更改已存在类的父类(superclass)。要指定您正在动态创建的类的父类(superclass),您

ruby-on-rails - rails : Only allow admin user to create new users in Rails with Devise (No external modules)

目前,我的Users数据库有一个名为“admin”的列,其值为bool值,默认设置为false。我有一个管理员用户播种到数据库中。如何编写我的应用程序以便是管理员的用户可以创建新用户,而不是的用户不能?(此外,用户应该仅由管理员创建)似乎应该有一种简单的方法可以在不涉及使用某些外部模块的设计中做到这一点。然而,到目前为止,我还没有找到满意的答案。我更有可能标记仅是设计的解决方案。(一个简单的标准MVC/Rails解决方案加分)但是,如果真的有更好的方法来做到这一点而不涉及CanCan,我可能也接受它。注意:我已经搜索了一段时间,发现了其他几个与这个问题非常相似的stackoverflo

ruby - 为什么在生产中使用 Net::HTTP 的 set_debug_output 是危险的?

Net::HTTP库中有一个非常有用的方法可以调试HTTP请求。这是文档对此的描述:set_debug_output(output)WARNINGThismethodcausesserioussecurityhole.Neverusethismethodinproductioncode.Setanoutputstreamfordebugging.http://ruby-doc.org/stdlib/libdoc/net/http/rdoc/classes/Net/HTTP.html#M001371这里提到的安全漏洞是什么? 最佳答案

ruby - 在 rails_admin 中,如何关闭相关子表单中的 "add new"和 "edit"按钮?

我想阻止人们从子表单中添加或编辑页面布局。基本上我想关闭下面截图中的按钮:我能做到这一点,还是必须在全局范围内关闭对整个页面布局模型的添加和编辑? 最佳答案 可能有点晚了,但你可以使用inline_add和inline_edit。例子:field:profiledoinline_addfalseinline_editfalseend 关于ruby-在rails_admin中,如何关闭相关子表单中的"addnew"和"edit"按钮?,我们在StackOverflow上找到一个类似的问题:

ruby-on-rails - Ruby on Rails : pretty print for variable. hash_set.inspect ...有没有办法在控制台中漂亮地打印 .inspect ?

我发现自己在我的功能测试中做了很多puts.inpsects以确保我知道数据是如何格式化的......但是当散列对象中的每个条目之后没有新行时散列很难读取.无论如何,也许是一个gem?,pretty-print哈希?所以它看起来像这样:{entry1=>{entrey1.1=>1,entry1.2=>3},entry2=>3}而不是:{entry1=>{entrey1.1=>1,entry1.2=>3},entry2=>3}?谢谢! 最佳答案 你可以为此使用awesome_printgem。https://github.com/mi

ruby-on-rails - rails : Ensure only one boolean field is set to true at a time

我有一个Logo模型,它的字段名称为:字符串,默认为bool值。我希望true值是唯一的,以便一次只能将数据库中的一项设置为true。如何在我的Controller中设置更新和新操作以将Logo的所有其余值设置为false?假设我有以下设置在我的数据库中模特标志名称:字符串|默认值:bool值|项目1|是的|项目2|假|第3项|假|如果我将Item2默认值更改为true,我希望它遍历所有Logo并将其余Logo设置为false,因此一次只有一个为true,所以它看起来像这样。名称:字符串|默认值:bool值|项目1|假|项目2|是的|第3项|假|提前感谢您的帮助。

ruby - 为什么 rubocop 或 ruby​​ 风格指南不喜欢使用 get_ 或 set_?

我在我的项目上运行rubocop并修复它提出的投诉。一个特别的提示困扰着我Donotprefixreadermethodnameswithget_我无法从这个投诉中了解太多,所以我查看了sourcecodeingithub.我找到了这个片段defbad_reader_name?(method_name,args)method_name.start_with?('get_')&&args.to_a.empty?enddefbad_writer_name?(method_name,args)method_name.start_with?('set_')&&args.to_a.one?end

ruby-on-rails - 如何优化 active_admin

上次我遇到active_admin的问题.在我有5000多行数据的表中,它的工作速度非常慢。我该如何优化它?也许有人知道这个模块的一些异步加载插件? 最佳答案 您可以做几件事。默认情况下,ActiveAdmin将关联加载为索引页面上的下拉过滤器。如果未使用这些过滤器,将它们移除会有所帮助,因为它们会实例化该模型的每条记录以构建下拉列表。ActiveAdmin.registerPostdoremove_filter:categoriesend如果您的索引页包含依赖于关联记录的列,则预先加载它们会有所帮助。ActiveAdmin.reg

ruby - 如何在 Ruby 中做 sane "set-difference"?

演示(我期待结果[3]):[1,2]-[1,2,3]=>[]#Hmm[1,2,3]-[1,2]=>[3]#Iseea=[1,2].to_set=>#b=[1,2,3].to_set=>#a-b=>#WTF!和:[1,2,9]-[1,2,3]=>[9]#Hmm.Wouldlike[[9],[3]]如何在不考虑输入顺序的情况下执行真正的集差异?附言。顺便说一句,我需要为两个2000元素的数组执行此操作。通常,数组#1的元素少于数组#2,但这并不能保证。 最佳答案 -operator应用于两个数组a和b给出relativecompleme