ASP.NET MVC4 웹 API 애플리케이션에서 POST에서 고객 데이터를 JSON으로 전달하려고 할 때 일반적인 문제가 발생합니다. 요청으로 인해 고객 속성에 null 값이 발생합니다. 이를 해결하려면 올바른 접근 방식을 이해해야 합니다.
처음에는 "Content-Type: application/x-www-form-urlencoded"를 기본 콘텐츠 유형으로 사용하는 것이 제안되었습니다. 그러나 이 접근 방식은 복잡한 개체 바인딩에 문제가 발생할 수 있으므로 더 이상 권장되지 않습니다.
올바른 개체 바인딩을 보장하려면 " application/json"을 콘텐츠 유형으로 사용합니다. 이는 JSON 데이터를 전송하고 있음을 서버에 지시하여 모델 바인더가 JSON 개체를 해당 클래스 개체에 올바르게 바인딩할 수 있도록 합니다.
코드 조각:
var customer = {contact_name :"Scott",company_name:"HP"}; $.ajax({ type: "POST", data :JSON.stringify(customer), url: "api/Customer", contentType: "application/json" });
설명:
"application/json"을 사용하여 우리가 보내는 데이터가 JSON 형식임을 서버에 명시적으로 알립니다. 이를 통해 모델 바인더는 JSON 데이터를 Customer 개체로 역직렬화하여 작업 메서드가 null 값 없이 고객 속성에 액세스할 수 있습니다.
모델 클래스가 중첩된 객체를 포함하여 복잡한 경우, 우리는 전송하는 JavaScript 객체가 뷰 모델 클래스의 구조와 일치하는지 확인해야 합니다. 그러면 모델 바인더가 중첩된 개체도 올바르게 바인딩할 수 있습니다.
일부 속성이 올바르게 바인딩되지 않은 경우 작업 메서드 매개 변수가 [FromBody]로 데코레이트되었는지 확인하세요. 기인하다. 이 속성은 모델 바인더에게 요청 본문에서 데이터를 찾도록 지시합니다. 또한 기본 콘텐츠 유형을 사용하고 부분 바인딩 문제가 발생할 수 있으므로 더 짧은 형식의 $.post를 사용하지 마세요.
이러한 지침을 준수하면 POST 요청에서 JSON 데이터를 객체로 효과적으로 전달할 수 있습니다. , 게시된 데이터가 ASP.NET MVC4 웹 API 애플리케이션의 적절한 클래스 개체에 올바르게 바인딩되었는지 확인합니다.
위 내용은 ASP.NET MVC4 웹 API 애플리케이션에서 POST 요청의 개체로 JSON 데이터를 전달할 때 적절한 개체 바인딩을 어떻게 보장합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!