我正在玩 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 %>