jquery ajax utf-8이 깨졌을 경우 어떻게 해야 하나요?

藏色散人
풀어 주다: 2023-02-17 09:46:02
원래의
2194명이 탐색했습니다.

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");"를 설정합니다.

jquery ajax utf-8이 깨졌을 경우 어떻게 해야 하나요?

이 튜토리얼의 운영 환경: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿