草庐IT

ruby-on-rails - 如何从 params 哈希中删除空参数?

在我的Rails4应用程序中,我有这样的设置:classInvoicesControllerclassInvoice?",params[:minimum])ifparams[:minimum]data=data.where("total问题是我有一堆其他GET参数,它们都是params散列的一部分。如何从URL中删除空白参数,这样我就不会得到如下URL:/invoices?after=&before=&maximum=&minimum=&number=感谢您的帮助。 最佳答案 把它放在哈希后面:.reject{|_,v|v.blan

ruby-on-rails - 带有字符串输入的引用模型

假设我希望创建一个页面,该页面可以使用type(string)和id(int)查询所需的对象。/query?type=people&id=1会接我Person.find(1)鉴于/query?type=cities&id=123会接我City.find(123)但是,关于如何将字符串转换为所需的模型类,我遇到了问题。我能想到的唯一办法是caseparams[:type]when'people'@object=Person.find(params[:id])when'cities'@object=City.find(params[:id])end但是,如果我有更多类型的模型,这种方法就会

ruby-on-rails - Rails 返回 JSON 序列化属性 with_indifferent_access

我以前有:serialize:params,JSON但这会返回JSON并将哈希键符号转换为字符串。我想使用符号引用散列,这在使用散列时最常见。我给它提供符号,Rails返回字符串。为了避免这种情况,我创建了自己的getter/setter。setter很简单(JSON编码),getter是:defparamsread_attribute(:params)||JSON.parse(read_attribute(:params).to_json).with_indifferent_accessend我不能直接引用params因为那会导致循环,所以我使用read_attribute,现在我的

ruby-on-rails - 在 Ruby if 条件下使用正则表达式

我正在尝试将正则表达式用作Ruby(1.9.2)if语句中的条件,但即使正则表达式的计算结果为nil,它也会一直返回trueif(params[:test]=~/foo/)return"match"elsereturn"nomatch"end即使Rails.logger.info(params[:test])显示测试设置为"bar",上面的代码也会返回“匹配” 最佳答案 ifparams[:test]=~/foo/#Successfulmatchelse#Matchattemptfailedend适合我。调试params[:test

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 - 在 Rails 控制台中创建实例时 Rails 4 强参数失败

可能在这里做了一些愚蠢的事情,但这是我的基本千篇一律类:classLeague在创建一个新的League实例时:2.0.0-p0:001>l=League.new(full_name:'foo',short_name:'bar')WARNING:Can'tmass-assignprotectedattributesforLeague:full_name,short_name我到底做错了什么?这是Rails4.0.0.beta1构建+Ruby2.0**更新**我现在意识到强参数现在是在Controller中强制执行的,而不是在模型中。原来的问题仍然成立。如果它们在Controller级别

ruby-on-rails - CanCan load_and_authorize_resource 触发 Forbidden Attributes

我有一个使用强参数的标准RESTfulController。classUsersController在我的config/initializers中,我有文件strong_parameters.rbActiveRecord::Base.send(:include,ActiveModel::ForbiddenAttributesProtection)当我向CanCan的load_and_authorize_resource添加一个简单的调用时,我得到了1)UsersControllerPOSTcreatewithinvalidparamsre-rendersthe'new'template

ruby-on-rails - Rails 4强参数无必填参数

我正在使用Rails4,但我不知道在没有必需参数的情况下使用强参数的最佳方法是什么。所以,这就是我所做的:defcreatedevice=Device.new(device_params).................endprivatedefdevice_paramsifparams[:device]params.require(:device).permit(:notification_token)else{}endend我的设备模型不验证任何东西的存在。我知道我也可以做类似的事情:device=Device.newdevice.notification_token=param

ruby-on-rails - Rails 4 更新嵌套属性

UpdatingNestedAttributesappend而不是updatingin有很多关系我正在尝试使用Rails4Update_attributesClassPerson在我的Controller中,我收到的参数是{id:23,house_no:'22A',pets:[{name:'jeffy',type:'dog'},{name:'sharky',type:'fish'}]}我的更新方法是defupdate@Person=Person.find(params[:id])if@Person.update(person_params)@Person.saverender'pers

ruby - 如何使用 new 干净地初始化 Ruby 中的属性?

classFooattr_accessor:name,:age,:email,:gender,:heightdefinitalizeparams@name=params[:name]@age=params[:age]@email=params[:email]...end这似乎是一种愚蠢的做法。在Ruby中初始化对象的更好/更惯用的方法是什么?ruby1.9.3 最佳答案 您可以只遍历键并调用setter。我更喜欢这个,因为如果你传递了一个无效的key,它会捕捉到。classFooattr_accessor:name,:age,:em