如何消毒葡萄树

时间:2014-05-30 14:02:44

标签: ruby-on-rails ruby grape-api

我想批量更新实体的属性。

如何正确消毒来自葡萄的化学物质?

这是关于参数的控制台日志:

params.except(:route_info, :token, :id)
=> {"display_number"=>"7"}
[18] pry(#<Grape::Endpoint>)> params.permit(:display_number)
ArgumentError: wrong number of arguments (2 for 0..1)
from /Users/boti/.rvm/gems/ruby-2.0.0-p353@thelocker/gems/hashie-2.0.5/lib/hashie/mash.rb:207:in `default'
[19] pry(#<Grape::Endpoint>)> params.sanitize
=> nil

1 个答案:

答案 0 :(得分:9)

在葡萄中你需要在实际方法之前声明你的参数。

在方法中,params对象是Hashie::Mash个实例,并且没有permitsanitize等API ...

Here是用于在葡萄中声明和验证参数的相关文档:

  

您可以为参数定义验证和强制选项   使用params块。

params do
  requires :id, type: Integer
  optional :text, type: String, regexp: /^[a-z]+$/
  group :media do
    requires :url
  end
  optional :audio do
    requires :format, type: Symbol, values: [:mp3, :wav, :aac, :ogg], default: :mp3
  end
  mutually_exclusive :media, :audio
end
put ':id' do
  # params[:id] is an Integer
end
     

如果指定了类型,则在完成后执行隐式验证   强制确保输出类型是声明的。

如果您仍想使用强参数,则需要使用strong_parameters gem,并创建ActionController::Paramter yourself的新实例:

raw_parameters = { :email => "john@example.com", :name => "John", :admin => true }
parameters = ActionController::Parameters.new(raw_parameters)
user = User.create(parameters.permit(:name, :email))
相关问题