【发布时间】:2018-01-31 14:17:57
【问题描述】:
我正在使用 ActiveStorage 并尝试在本地上传一些文件。下面的代码一切正常,但前提是我从表单中删除multiple: true。当它在表单上时,我在控制台中收到未经许可的参数“文件”错误。未经许可的参数来自表单提交哈希的方式。
如果没有multiple: true,哈希将附件列为数组(这是工作版本):
"article"=>{"files"=>[#<ActionDispatch::Http::UploadedFile:0x007fb4e8e287f0
但是打开它会删除数组:
"article"=>{"files"=>#<ActionDispatch::Http::UploadedFile:0x007fb4eb07b7d0
是什么导致了这种表单行为,我该如何解决?
我从Engine Yard 获得了代码示例,这里是项目代码:
<h3>Attach files to this post</h3>
<%= form_with model: @article, local: true do |f| %>
<div class="form-row">
<%= f.label :file_upload, 'Attach a file' %>
<%= f.file_field :files, multiple: true %>
</div>
<%= f.submit %>
<% end %>
<h3>Attached files</h3>
<% @article.files.each do |file| %>
<%= link_to file.blob.filename, url_for(file) %>
<% end %>
【问题讨论】:
-
您的控制器参数看起来如何?使用
multiple: true时,应设置:files参数以查找数组。 -
我将参数更改为读取
params.require(:article).permit(:author, :text, [:files])并且确实格式化传递的参数以匹配工作示例,但我仍然得到未经许可的参数“文件”
标签: ruby-on-rails forms rails-activestorage