이번에는 jQuery의 잘못된 중국어 매개변수 전송 요청을 빠르게 해결하는 방법과 jQuery의 잘못된 중국어 매개변수 전송 요청 문제를 빠르게 해결하기 위한 주의사항에 대해 설명하겠습니다. 실제 사례를 살펴보겠습니다.
최근 작업 중인 요구 사항에는 계단식 쿼리가 포함되어 있습니다. 상위 수준 드롭다운 상자의 내용을 기반으로 하위 수준 드롭다운 상자 목록을 쿼리해야 합니다. 캐스케이드하면 테이블의 데이터가 나중에 거의 변경되지 않습니다. 그래서 제가 디자인한 테이블은 중국어로 직접 저장됩니다.
메뉴는 다음과 같습니다.
코드는 다음과 같습니다.
var url = "${basePath}/institutionConfig/getDepartmentByCenter.do?param=" + center; $.get(url, function (data) { var list = data.data; for (var i = 0; i " + list[i] + ""; } $("#accountDepartmentAdd").html(departmentSelector); });
저는 $.get(url, callback)
를 사용하여 백그라운드로 요청을 보냅니다. GET 모드에서 매개변수가 직접 전송되므로 브라우저는 매개변수를 URL 인코딩으로 인코딩합니다. , 및 배경 획득된 매개변수는 다음과 같습니다.
수신된 매개변수가 잘못된 코드임을 알 수 있습니다. 그래서 추가 처리, 즉 트랜스코딩을 수행했습니다.
String center = new String(param.getBytes("iso8859-1"), "utf-8");
이렇게 해서 수신된 텍스트는 중국어입니다.
그런데 이 접근 방식은 실제로 테스트 환경에서 오류를 보고했습니다. 이유를 분석한 결과 테스트 환경에서 올바른 중국어를 수신한 것으로 나타났으나 트랜스코딩을 한 결과 잘못된 것으로 나타났습니다. 따라서 해결책은 페이지 요청을 변경하는 것입니다. GET 메소드로 인한 매개변수가 인코딩되므로 POST 요청으로 변경됩니다. POST 요청은 원본 데이터를 제출합니다.
var url = "${basePath}/institutionConfig/getDepartmentByCenter.do"; $.ajax({ url: url, data: {"param": center}, dataType: "json", type: "POST", success: function (data) { var list = data.data; for (var i = 0; i " + list[i] + ""; } $("#accountDepartmentAdd").html(departmentSelector); } });
이 기사의 사례를 읽은 후 메소드를 마스터했다고 생각합니다. 자세한 내용은 다른 PHP 중국어 웹사이트에 주목하세요!
추천 자료:
CodeIgniter 프레임워크 데이터베이스 사용 사례 분석
위 내용은 잘못된 중국어 매개변수를 전송하라는 jQuery의 요청을 신속하게 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!