Reactjs
React 'axios' POST방식 request body,request header 에 데이터 담아 요청 보내기
DevilFront
2021. 9. 3. 10:23
반응형
기존의 짜여져 있는 프로젝트 코드를 수정하던 중 post 로 요청을 받고 있지만 params 에서 일부 데이터를 가져오고 나머지는 request body 에서 또 플러스 알파로 필요하면 request header 에 필요한 정보 (인증이라 던지... 인증이라던지... 권한이라던지.. )를 추가해주는 것까지 한 번 간단히 사용법을 알아보자.
https://github.com/axios/axios <= 기본적인 사용법들, 문법들을 전체적으로 확인 할 수 있다.
우선 axios 가 당연히 깔려 있어야 겠다. 깔려있지 않다면
npm i axios
이제 이벤트가 발생 했거나 본인이 원할 때 한번 데이터를 전송해보자
나 같은 경우에는 가격을 request body 에 상품의 암호화 되어 있는 id를 url에 , 인증토큰을 request header 에 담아서 넘겨줘야 했다. (요청을 받는 백엔드 쪽 api가 그렇게 설정이 되어 있었당 ㅠㅠ);
const sendData = async() => {
try
const res = await axios.post(1,2,3);
catch(error)
error
}
크게 요런 식으로 쓰게 될 텐데 1의 인자, 2의 인자, 3 의 인자에 어떤 것을 넣어주느냐에 따라 각각 원하는 데이터를 전달 할 수 있다.
저기 1번 인자에는 주소를 , 2번인자에는 body 정보를, 3번쨰 인자에는 header 에 넣어줄 정보를 각각 넣어주면 된다.
const sendData = async(Datum) => {
const id = Datum._id;
const headers = {
'Content-Type' : 'application/json',
'Authorization' : authToken
}
console.log(id);
try {
console.log(price);
const res = await axios.post(`~~/${id}/place-deal`, {
price : price // price라는 이름의 객체에 price 변수에 담은 값 전달
},{
headers:headers // headers에 headers 객체 전달
}
)
console.log(res);
setPrice(0); // ~~
} catch (error) {
console.log(error);
}
}
요런 식으로 해주고 개발자 도구에서 network 클릭해서 보게 되면 headers 에 우리가 넣어준 객체 값과 맨 밑에 body 에 넣어준 값들이 잘 나오는 것을 확인 할 수 있다.
반응형