如何从FormData设置包装器数据?

问题描述 投票:0回答:2

如何从FormData设置包装器数据?

我在Rails中使用CarrierWave。 我正在从ajax调用Web API。

此命令已成功完成。

curl -X POST \
https://site-url/api/books/ \
-H 'cache-control: no-cache' \
-H 'content-type: multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW' \
-F 'book[title]=test' \
-F book[image]=@kindle_3_0_library_ipad_iphone.jpg \
-F 'book[genre_id]=1'

这是当时的development.log。

Parameters: {"book"=>{"title"=>"test", "image"=>#<ActionDispatch::Http::UploadedFile:0x0000000005f1d790 @tempfile=#<Tempfile:/tmp/RackMultipart20181016-37646-65mtjc.jpg>, @original_filename="kindle_3_0_library_ipad_iphone.jpg", @content_type="image/jpeg", @headers="Content-Disposition: form-data; name=\"book[image]\"; filename=\"kindle_3_0_library_ipad_iphone.jpg\"\r\nContent-Type: image/jpeg\r\n">, "genre_id"=>"1"}}

此代码失败。

var request = new FormData();
request.append('title', title);
request.append('image', imageFile, imageFile.name);
request.append('genre_id', 1);

这是当时的development.log。

Parameters: {"title"=>"test", "image"=>#<ActionDispatch::Http::UploadedFile:0x00007f01dc083240 @tempfile=#<Tempfile:/tmp/RackMultipart20181016-37646-3zmceu.jpg>, @original_filename="41fQlZLtDgL._SX337_BO1,204,203,200_.jpg", @content_type="image/jpeg", @headers="Content-Disposition: form-data; name=\"image\"; filename=\"41fQlZLtDgL._SX337_BO1,204,203,200_.jpg\"\r\nContent-Type: image/jpeg\r\n">, "genre_id"=>"1"}

其他试过这个。

var request = new Object();
request.book = new FormData();
request.book.append('title', title);
request.book.append('image', imageFile, imageFile.name);
request.book.append('genre_id', 1);

这是当时的development.log。

Parameters: {"object Object"=>nil}

我不知道如何设置可以保存的参数。 谢谢

javascript ruby-on-rails carrierwave multipartform-data form-data
2个回答
0
投票

表单数据应该有multipart/form-data的标题。

const formData = new FormData();
const config = {
  headers: {
    'content-type': 'multipart/form-data'
  }
}

axios.post("/URL", formData, config)
    .then(...)

这个链接也是关于那个,完全不同的问题。 ActiveStorage and Image upload


0
投票

这个问题解决了。

request.append('book[title]', title);
© www.soinside.com 2019 - 2024. All rights reserved.