프로젝트 진행 중 주문번호를 입력하면 ajax를 이용해 비동기 형식으로 해당 주문번호의 상세정보들을 출력하게 만들고 싶었다.
기존에 그냥 주문번호 박아놓고 조회 진행하다가.. 실제로 구현되는거는 주문번호 하나가 아니니까...
사실 현재 주문 리스트를 실시간으로 출력하고 해당 리스트에서 출력된 주문번호에 ajax걸어서 출력하려고 했는데...
테스트하기위한 주문내역이 1도 없어서 ^^.......개가튼...
여튼 당장은 동작하는것을 코알못분들에게 보여줘야하기 때문에 급한대로 input 박스에 주문번호를 입력하고 버튼을 누르면 주문번호에 대한 상세 정보를 출력하게 만드는 중이었다...
POST로 요청하는데 orderIds가 안보내지는 것이었다 ㅠ
$('#orderDetailBtn').click(function (){ var orderIds = $('#orderIds').val(); console.log(orderIds); $.ajax({ type: "POST", url: "/orderDetail", contentType: "application/json", data: "orderIds=" + orderIds, ....
이 상태로 실행할 경우 출력되는 오류 메시지는 이렇다.
2023-07-21 14:30:14.525 WARN 13140 --- [nio-9099-exec-2] .w.s.m.s.DefaultHandlerExceptionResolver : Resolved [org.springframework.web.bind.MissingServletRequestParameterException: Required request parameter 'orderIds' for method parameter type String is not present]
이 오류 메시지에 대해서 구글링하면 전부 contoller의 @RequestParam 에
required=false를 추가해주라는 말밖에 없었다 ㅡㅡ 심지어 스택오버플로우에서조차.... 하...
근데 내 오류는 이게 아니었고...
심지어 필수로 넘겨줘야하는 데이터인데 required=false를 추가하면 오류가 해결된다는게 말인가?,,.,
추가하면 null이 넘어갈것이 뻔한디?
구글링하는 것을 포기하고
지피티에게 도움을 요청해보니 contentType을 변경하라고 했다
그래서 바꾸니까 진짜 말짱하게 되는것이 아니겠는가?!!
$('#orderDetailBtn').click(function (){ var orderIds = $('#orderIds').val(); console.log(orderIds); $.ajax({ type: "POST", url: "/orderDetail", contentType: "application/x-www-form-urlencoded", data: "orderIds=" + encodeURIComponent(orderIds), ..... //// controller단 @PostMapping("/orderDetail") @ResponseBody public String gerOrderDetail(@RequestParam("orderIds")String orderIds){ JSONArray orderDetails = smartStoreUtil.getOrderDetail(orderIds); return orderDetails.toString();
그럼 도대체
application/x-www-form-urlencoded
와 application/json
의 차이가 무엇이길래 나같은 빡대갈은 쉽게 해결하지 못했는가??
api연동할때 보내는 자원을 명시하기 위해서 사용.
HTTP 요청을 보낼 때 사용되는 헤더 중 하나로, 요청 본문의 데이터 타입을 지정하는 역할을 한다.
요청에 포함된 데이터가 어떤 형식으로 인코딩되었는지 서버에게 알려주는 역할을 한다.
이는 서버가 요청을 올바르게 처리하고 데이터를 파싱하는 데 도움을 준다.
MessageBody에 들어가는 타입을 HTTP Header에 명시해주는 필드이다.
웹 양식 데이터를 인코딩하는데 사용되는 기본 데이터 유형!
주로 HTML 폼 요소에서 사용자로부터 입력된 데이터를 서버로 전송하는데 사용하며 API요청에서도 사용된다.
데이터 교환 형식으로 많이 사용된다. 서버와 클라이언트 간에 구조화된 데이터를 교환하는데 사용한다. 웹 어플리케이션과 API에서 데이터를 전송하고 수신하는데 자주 사용된다.
{}
로 둘러싸고, 각 키와 값은 콜론:
으로 연결. 각 데이터 항목은 쉼표로 구분.application/x-www-form-urlencoded
는 간단한 폼 데이터를 전송하는 데 유용application/json
은 구조화된 데이터를 교환하는 데 적합
블로그 작성자님의 프로젝트 경험 및 과정을 잘 읽었습니다. 개발 과정에서 발생하는 오류를 해결하고자 하는 당신의 노력과 창의적인 해결책을 찾아내는 능력이 인상적입니다. 특히
application/x-www-form-urlencoded
와application/json
의 차이점에 대한 설명은 매우 도움이 되었습니다. 계속해서 공유해주신다면 더 많은 사람들이 도움을 받을 수 있을 것 같습니다. 화이팅입니다!