쿠키를 사용하면서 우리는 다음과 같은 문제를 발견했습니다. 쿠키에 기록된 내용이 중국어(예: 사용자 이름)인 경우 서버측 프로그램(예: ASP 또는 PHP)으로 읽는 것이 완전히 정확합니다. , 하지만 일반 javascript나 VBScript로 읽어보면 완전히 맞습니다. Cookie 함수가 꺼내는 것은 횡설수설입니다. 어떤 경우에는 클라이언트 측에서 스크립트 언어를 사용하여 쿠키의 내용을 읽어야 하기 때문에 이는 까다로운 문제입니다. 중국어를 쓰다가 글자가 깨져서 잔뜩 나오면 어색하게 느껴지나요? 이 문제를 해결하려면 쿠키 액세스 방법부터 시작해야 합니다.
쿠키 콘텐츠를 작성하기 전에 이스케이프(16진수 인코딩)가 필요하며 인코딩은 바이트 단위라는 것을 알고 있습니다. 이것이 문제의 핵심입니다. 모든 중국어 문자는 각 섹션이 별도로 인코딩됩니다. 쿠키를 읽을 때 unescape는 바이트 단위로 디코딩하므로 결국 각 한자는 2바이트의 잘못된 코드가 됩니다. 무엇을 해야 할까요? ASP 또는 PHP 메소드를 올바르게 읽을 수 있는 경우 이스케이프 해제 디코딩 후 한자가 유니코드 인코딩에 따라 표기되어야 합니다. 이런 경우, 이 문제를 해결할 수 있는 해결 방법을 찾을 수 있습니까? 신중하게 연구한 결과, 16진수 코덱(인코딩 및 디코딩) 프로세스 중에 한자 정보를 저장할 수 있는 한 다른 코덱 프로세스를 아웃소싱해야 한다는 것을 발견했습니다.
1. 이스케이프 인코딩 전에 쿠키 문자열의 각 문자를 유니코드 코드의 문자열 형식으로 변환합니다(특수 문자를 문자열 구분 기호로 사용).
2. 언이스케이프 디코딩 후 먼저 모든 유니코드 문자열을 추출한 후 해당 함수를 사용하여 원본 문자로 변환합니다.
예를 들어 작성하려는 쿠키 내용은 "一丁ABC"인데 CodeCookie 이후에는 "99a98a97a-31029a26432a"로 변경되고(보안상의 이유로 문자열은 반전됨) 이후에는 "99a98a97a-31029a26432a"가 됩니다. "(이스케이프 인코딩은 문자와 숫자 이외의 문자를 16진수 %XX 형식으로 변환합니다.) 구분 기호는 %, D 및 숫자일 수 없습니다. 물론, 비밀번호 등 중요한 정보가 있는 경우에는 암호화를 강화해야 합니다. 쿠키는 일반적으로 짧은 메시지로 작성되므로 인코딩 후 추가되는 바이트 수는 무시할 수 있습니다. 위 중국어 지원이 다음 자바스크립트 읽기 및 쓰기 쿠키 기능에 추가되었습니다.
function SetCookie(name,value,expires)
{
var exp=new Date()
exp.setTime(exp.getTime()expires*60*1000); 🎜> document.cookie=name "=" escape(CodeCookie(value)) " ; 만료=" exp.toGMTString() " ; path=/";
}
function GetCookie(이름)
{
var strArg=name "="
var nArgLen=strArg.length;
var nCookieLen=documents.cookie.length;
var nEnd;
var j;
while (i{
j=i nArgLen
if (documents.cookie.substring(i,j)==strArg)
{
nEnd=documents.cookie.indexOf (";",j);
if (nEnd==-1) nEnd=documents.cookie.length;
return DecodeCookie(unescape(documents. cookie.substring(j,nEnd)));
}
i=documents.cookie.indexOf(" ",i) 1
if (i==0)
}
return null;
}
CGI 프로그램을 사용하여 중국어 쿠키를 작성하면 클라이언트가 이를 읽습니다. 예를 들어 ASP에서는 앞서 언급한 인코딩 기능을 먼저 사용한 다음 응답으로 작성할 수 있습니다. 예: response.cookies("Name")=CodeCookie("Zhang San") 이때 중국 쿠키의 문제점은 다음과 같습니다. 기본적으로 해결되었습니다.