реагировать на данные родной формы сообщения с объектом и файлом в нем, используя axios - PullRequest
0 голосов
/ 21 мая 2019

enter image description here

, поэтому я хочу загрузить объект в виде данных и файла в качестве примечания к API с помощью axios

uploadToServer= () => {
    const file =this.state.photo

  let data2 ={sale_id:1,
            note_type_id:4,
            description:"test",
            note_content_item:" hi from broker hub"
            
            }



let data = new FormData()
data.append('data[sale_id]', '1')
data.append('data[note_type_id]', '4')

data.append('data[description]', "test")

data.append('data[note_content_item]', "test")







console.log(data)


axios({
  url: api',
  method: 'POST',
  data: data,
  headers: {
   
            'Content-Type' : 'multipart/form-data',
          'Authorization':'Basic YnJva2VyOmJyb2tlcl8xMjM='

  }
})
        .then(resp => console.log(resp.data.response))
        .catch(error => console.error(error)); 

}

сначала я пытаюсь с данными без примечания, я могу сделать это в почтальоне

enter image description here

но с моим кодом я получил сообщение об ошибке

: "Не удается сохранить файл" код_ответа: 10

Я получил эту ошибку, только если я изменил ключ от данных на что-то другое enter image description here

1 Ответ

0 голосов
/ 21 мая 2019

Вы неправильно строите FormData, попробуйте это:

let data = {sale_id:1,
                note_type_id:4,
                description:"test",
                note_content_item:" hi from broker hub"            
                }
const formData = new FormData();
formData.append('data', JSON.stringify(data));
formData.append('Note', {
                     uri: "file://" //Your Image File Path
                    type: 'image/jpeg', 
                    name: "imagename.jpg",
                  });
axios({
       url    : api,
       method : 'POST',
       data   : formData,
       headers: {
                    Accept: 'application/json',
                    'Content-Type': 'multipart/form-data',
                    'Authorization':'Basic YnJva2VyOmJyb2tlcl8xMjM='
                }
            })
            .then(function (response) {
                    console.log("response :", response);
           })
           .catch(function (error) {
                    console.log("error from image :");
           })
...