jquery ajax utf-8 왜곡된 코드에 대한 해결 방법: 1. contentType 인코딩을 "utf-8"로 설정하고 코드를 "contentType: "application/x-www-form-urlencoded;charset=utf-8""로 설정합니다. 2에서는 PrintWriter 객체를 얻기 전에 "resp.setContentType("text/text;charset=GBK");"를 설정합니다.
이 튜토리얼의 운영 환경: Windows 10 시스템, jquery3.2.1 버전, Dell G3 컴퓨터.
jquery ajax utf-8이 깨졌을 경우 어떻게 해야 하나요?
jQuery AJAX가 잘못된 코드를 요청하고 잘못된 코드를 반환합니다
1. jQuery AJAX 요청이 백그라운드에서 잘못된 코드로 수신됩니다.
contentType의 인코딩을 utf-8로 명시적으로 설정할 수 있으며, 백그라운드는 일반적으로 정상적으로 디코딩될 수 있습니다. 예:
contentType: "application/x-www-form-urlencoded; charset=utf-8",
jQuery(form).ajaxSubmit({ url: "doLogin?user=a", type: "post", dataType: "json", contentType: "application/x-www-form-urlencoded; charset=utf-8", success: showLoginResponse });
contentType을 추가하지 않은 경우: "application/x-www-form-urlencoded; charset=UTF-8", escape() 사용 시 "게시물 본문에 지정된 콘텐츠 길이보다 적은 바이트가 포함되어 있습니다. "가 나타납니다
오류.
2. jQuery AJAX가 잘못된 문자를 반환합니다.
인코딩을 어떻게 설정하더라도 클라이언트가 수신한 데이터가 항상 왜곡된다는 사실을 발견하셨나요? 아래 예를 살펴보시기 바랍니다. 문제가 있나요?
void saveTempKind(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { PrintWriter pw = resp.getWriter(); resp.setContentType("text/text;charset=GBK"); try { //DO PROCESS pw.write("成功"); }catch(Exception e){ pw.write("失败"); } }
문제는 resp.setContentType("text/text;charset=GBK"); 문이
PrintWriter pw = resp.getWriter();
뒤가 아니라 앞에 있어야 한다는 것입니다. 위의 예와 같다면 응답 인코딩을 어떻게 설정하더라도 프런트 엔드 왜곡 문제는 여전히 동일하게 유지됩니다. 가능한 이유는 pw가 PriintWriter를 얻기 전에 인코딩이 결정되었기 때문입니다. 따라서 인코딩 문은 PrintWriter 개체를 가져오기 전에 이루어져야 합니다.
추천 학습: "
jQuery 비디오 튜토리얼위 내용은 jquery ajax utf-8이 깨졌을 경우 어떻게 해야 하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!