다중 부분 양식 데이터로 게시물 가져 오기
다음과 같은 URL을 가져옵니다.
fetch(url, {
mode: 'no-cors',
method: method || null,
headers: {
'Accept': 'application/json, application/xml, text/plain, text/html, *.*',
'Content-Type': 'multipart/form-data'
},
body: JSON.stringify(data) || null,
}).then(function(response) {
console.log(response.status)
console.log("response");
console.log(response)
})
내 API는 데이터가 될 것으로 예상 하므로이 유형을 multipart/form-data
사용 content-type
하고 있지만 상태 코드 400으로 응답을 제공합니다.
내 코드에 어떤 문제가 있습니까?
당신은이 설정하는 Content-Type
것으로 multipart/form-data
,하지만 사용 JSON.stringify
하는 반환 본문 데이터에 application/json
. 콘텐츠 유형이 일치하지 않습니다.
multipart/form-data
대신 데이터를 인코딩해야합니다 json
. 일반적으로 multipart/form-data
파일을 업로드 할 때 사용되며 application/x-www-form-urlencoded
(HTML 양식의 기본값) 보다 약간 더 복잡 합니다.
사양 multipart/form-data
은 RFC 1867 에서 찾을 수 있습니다 .
자바 스크립트를 통해 이러한 종류의 데이터를 제출하는 방법에 대한 가이드는 여기를 참조 하세요 .
기본 아이디어는 FormData 객체 를 사용하는 것입니다 (IE <10에서는 지원되지 않음).
function sendData(url, data) {
var formData = new FormData();
for(var name in data) {
formData.append(name, data[name]);
}
fetch(url, {
method: 'POST',
body: formData
}).then(function (response) {
...
});
}
당 https://muffinman.io/uploading-files-using-fetch-multipart-form-data/ 확인 하지 세트에 Content-Type
헤더를. 브라우저가 boundary
매개 변수를 포함하여 설정합니다.
나는 최근에 IPFS와 함께 일하고 있었고 이것을 해결했습니다. IPFS가 파일을 업로드하는 컬 예제는 다음과 같습니다.
curl -i -H "Content-Type: multipart/form-data; boundary=CUSTOM" -d $'--CUSTOM\r\nContent-Type: multipart/octet-stream\r\nContent-Disposition: file; filename="test"\r\n\r\nHello World!\n--CUSTOM--' "http://localhost:5001/api/v0/add"
기본적인 아이디어는 각 부분 (의 문자열로 분할한다는 것입니다 boundary
과는 --
) 그 자체 헤더있다 ( Content-Type
예를 들어, 두 번째 부분에서하십시오.) FormData
그것이 우리의 목표를 달성 할 수있는 더 좋은 방법이 그래서 개체가 당신을 위해 모든 것을 관리합니다.
이것은 다음과 같은 API를 가져 오는 것으로 변환됩니다.
const formData = new FormData()
formData.append('blob', new Blob(['Hello World!\n']), 'test')
fetch('http://localhost:5001/api/v0/add', {
method: 'POST',
body: formData
})
.then(r => r.json())
.then(data => {
console.log(data)
})
참고URL : https://stackoverflow.com/questions/35192841/fetch-post-with-multipart-form-data
'IT박스' 카테고리의 다른 글
기존 MVC 웹 응용 프로그램에 웹 API를 추가 한 후 404 오류 (0) | 2020.12.04 |
---|---|
Objective-C에서 Swift 유형의 속성에 액세스 할 수 없습니다. (0) | 2020.12.04 |
모든 오브젝트 파일을 별도의 디렉토리에 배치하는 gcc / g ++ 옵션 (0) | 2020.12.04 |
정의로 이동을위한 키보드 단축키 (0) | 2020.12.04 |
객체가 특정 유형의 배열인지 확인하는 방법은 무엇입니까? (0) | 2020.12.04 |