0

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

1 回答 1

2

当您使用时,您需要在formultiple: true中允许显式数组:article_params:files

例如:

params.require(:article).permit(:author, :text, files: [])

您可以在动作控制器下阅读更多内容

祝你好运!

于 2018-01-31T18:22:26.293 回答