이번에는 네이티브 Ajax의 MIME 유형(코드 포함)을 가져왔습니다. 네이티브 Ajax에서 MIME 유형을 구현하는 데 필요한 주의 사항은 무엇입니까?
문제 설명
다음 예는 Ajax post 요청의 코드입니다. 이 코드를 테스트하고 실행한 결과 반환된 상태 코드는 400이었습니다. 나중에 서버가 이해할 수 없었습니다. 확인하고 수정한 결과 다음 코드는 약간만 수정하면 됩니다
원본 코드
var send = function (url, params, fn) { var me = this; var xhr = null; var data = ''; fn = fn || function() {}; params = params || {}; for(var item in params) { data += item + '=' + params[item] + '&'; } if(data[data.length - 1] == '&') { data = data.slice(0, data.length - 1); } if(window.XMLHttpRequest) { xhr = new XMLHttpRequest(); }else if(window.ActiveXObject) { xhr= new ActiveXObject("Microsoft.XMLHTTP"); } xhr.open("post", url, true); xhr.setRequestHeader("Content-type", "application/json"); xhr.onreadystatechange = function () { if(xhr.readyState == 4 && (xhr.status == 200 || xhr.status == 304)) { fn(JSON.parse(xhr.responseText)); } }; xhr.send(JSON.stringify(params)); }
수정된 코드
var send = function (url, params, fn) { var me = this; var xhr = null; fn = fn || function() {}; params = params || {}; if(window.XMLHttpRequest) { xhr = new XMLHttpRequest(); }else if(window.ActiveXObject) { xhr= new ActiveXObject("Microsoft.XMLHTTP"); } xhr.open("post", url, true); xhr.setRequestHeader("Content-type", "application/json"); xhr.onreadystatechange = function () { if(xhr.readyState == 4 && (xhr.status == 200 || xhr.status == 304)) { fn(JSON.parse(xhr.responseText)); } }; xhr.send(JSON.stringify(params)); }
코드는 수정된 코드입니다. 데이터 변수 의 처리가 제거되고 send에 전달된 매개변수가 params 변수
Problem Solving
으로 변경되었습니다. 문제는 해결되었지만 의심스러운 점은 내 마음이 생겼다. 이전에 사용했던 네이티브 Ajax에서는 메소드가 post일 때 전달된 매개변수가 "name=123&age=32" 형식인데 왜 지금 직렬화된 JSONobject을 전달해도 괜찮은 걸까?
이 때 제가 추가한 MIME 유형을 발견했는데, 여기서 Content-type을 "application/json"으로 설정했는데, 이때 일반적으로 사용되는 The가 생각났습니다. MIME 유형은 "application/x-www-form-urlencoded"입니다. 이 경우 send 메소드로 전달되는 매개변수는 "name=123&age=32"여야 합니다. 이제 혼란은 끝났습니다(~ ̄▽ ̄). ~
보충
그나저나 상태코드가 405 입니다. 지난번에 봤을 때 프론트엔드에서 요청을 보냈을 때 전달된 매개변수가 잘못되어 이번에 마주쳤습니다. , 백엔드가 아직 이 요청에 대한 처리를 추가하지 않았기 때문입니다
이 기사의 사례를 읽으신 후 방법을 익히셨을 것이라 믿습니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!
추천 자료:
신분증과 은행 카드 번호의 형식을 결정하는 정규식 작성 방법
JS 정규식을 사용하여 0이 아닌 양의 정수를 확인하는 방법
위 내용은 네이티브 Ajax MIME 유형 구현(코드 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!