2016-04-13 41 views
0

で始まる必要があります。carrierwaveで複数のファイルをアップロードし、それらを雲雲にアップロードしようとしていますが、画像URLをpsql配列の列に保存しています。 は、私はこのエラーを取得する:それは、 "{}" で始まる場合、またはそれがliterarせずにそれを望んでいるRails carrierwave複数アップロードpsql配列の値は、 "{"

INSERT INTO "products" ("title", "images", "created_at", "updated_at") VALUES ($1, $2, $3, $4) RETURNING "id" [["title", ""], ["images", "{u5fzgamsmt2rmnusees5.jpg,oznphywjmfykswlzzgit.jpg,x4kzdzgggzpnf7ho0w5e.jpeg,v4dlu4sdtbbtiaspvmu2.jpeg}"], ["created_at", "2016-04-13 09:31:48.306261"], ["updated_at", "2016-04-13 09:31:48.306261"]] 

ActiveRecord::StatementInvalid (PG::InvalidTextRepresentation: ERROR: malformed array literal: "image/upload/v1460539908/u5fzgamsmt2rmnusees5.jpg" 
LINE 1: UPDATE "products" SET "images" = 'image/upload/v1460539908/u... 
            ^
DETAIL: Array value must start with "{" or dimension information. 
:UPDATE "products" SET "images" = 'image/upload/v1460539908/u5fzgamsmt2rmnusees5.jpg' WHERE "products"."id" = $1): 
app/controllers/products_controller.rb:26:in `create' 

受け取ったのparamsを SQLなど、複数のファイルを送信して、右のようです""?

移行:

class AddImagesToProducts < ActiveRecord::Migration 
    def change 
    add_column :products, :images, :string, array: true, default: [] 
    end 
end 

スキーマ:

create_table "products", force: :cascade do |t| 
t.string "title" 
t.text  "description" 
t.decimal "price" 
t.datetime "created_at",     null: false 
t.datetime "updated_at",     null: false 
t.integer "department_id" 
t.integer "category_id" 
t.string "images",  default: [],    array: true 
end 

コントローラー:

def create 
    @product = Product.new(product_params) 
    @product.save 
end 

private 

    def product_params 
    params.require(:product).permit(:title, {images: []}) 
    end 

class Product < ActiveRecord::Base 
mount_uploaders :images, ImageUploader 
end 

EDIT 変更params.require(:製品).permit(:タイトル、画像:[ ]))をparams.require(:product).permit(:title、{images:[]})に変更しますが、まだ何もありません

EDIT2 フォーム:

<%= stylesheet_link_tag "navbar" %> 
<%= form_for @product, :html => {:multipart => true} do |f| %> 
<p> 
<%= f.label :title %><br /> 
<%= f.text_field :title %> 
</p> 
<p> 
<%= f.file_field :images, multiple: true %> 
</p> 
<p><%= f.submit %></p> 
<% end %> 

答えて

0

問題は、私が使っていたcloudinary宝石であるようなので、それが見える、彼らはまた、psql JSONまたは配列の列のがサポートされていません。だから、私がそれを働かせたのは製品のコントローラだった、と私は付け加えた:

params[:product][:images].each do |image| 
    Cloudinary::Uploader.upload(image) 
end 
関連する問題