HTTP 상태 비저장 프로토콜은 프로토콜에 트랜잭션 처리를 위한 메모리 기능이 없음을 의미합니다.
세션 추적
프로토콜의 상태는 전송 정보를 "기억"하는 다음 전송의 능력을 나타냅니다. 브라우저가 서버에 요청을 보내면 서버가 응답하지만, 동일한 브라우저가 다시 서버에 요청을 보내면 응답을 하게 되지만, 지금은 자신이 동일한 브라우저인지는 알 수 없습니다. 상대적으로 독립적입니다.
쿠키의 가장 일반적인 적용은 등록된 사용자가 웹사이트에 로그인했는지 여부를 확인하는 것입니다. 사용자는 다음 번에 이 웹사이트에 접속할 때 사용자 정보를 유지할 것인지 묻는 메시지를 표시하여
Javascript는 쿠키를 사용합니다
이런 상황이 있다고 가정해 보겠습니다. A 페이지에서 B 페이지로 이동합니다. A 페이지에서 JS를 사용하여 temp 변수를 사용하여 특정 변수의 값을 저장하는 경우, B,
이 변수의 값입니다. 다시 로드됩니다. 즉, 저장 효과가 달성되지 않습니다. 이 문제에 대한 가장 좋은 해결책은 쿠키를 사용하여 변수의 값을 저장하는 것입니다. 그렇다면 쿠키를 설정하고 읽는 방법은 무엇입니까?
먼저 쿠키의 구조에 대해 조금 이해해야 합니다. 간단히 말하면 쿠키는 키-값 쌍의 형태, 즉 키=값 형식으로 저장됩니다. 각 쿠키는 일반적으로 ";"으로 구분됩니다.
H5에서 webStorage는 실제로 웹에 데이터를 저장하는데 이는 두 가지 유형으로 나뉩니다.
sessionStorage 저장된 데이터는 브라우저를 닫으면 사라집니다. --- 임시 저장소
Set
세션 저장소:
sessionStorage.setItem("smessage",dataDom.value);
Get
sessionStorage.getItem("smessage")
사용: 삭제 지정 키 로컬 저장소의 값
사용법: .removeItem(key)
sessionStorage.removeItem("key"); localStorage.removeItem("site")
clear 모든 키/값 지우기
Usage : 모든 키/값 지우기
사용법: .clear()
코드 예:
sessionStorage.clear();
1. 쿠키는 일반적으로 4095kb보다 크지 않습니다.
2. 클라이언트와 서버 모두 데이터에 액세스할 수 있습니다
3. 제한된 기간
로컬 저장: 로컬 브라우저만 액세스할 수 있으며, 각 도메인 크기는 5M입니다.
만료 시간이 없습니다.
쿠키가 핵심입니다. -value pair key=value 형식으로 저장됩니다. 각 쿠키는 일반적으로 ";"로 구분됩니다.
document.cookie="name="+username;
//JS 쿠키 운영 방식!
//쿠키 쓰기
{
var Days = 30;
var exp = new Date();
exp.setTime(exp.getTime() + Days*24*60*60*1000 );
document.cookie = 이름 + "="+ 이스케이프(값) + ";expires=" + exp.toGMTString();
}
//쿠키 가져오기
function getCookie(이름)
{
if(arr=document.cookie.match(reg))
return unescape(arr[ 2]);
else
return null;
}
//쿠키 삭제
function delCookie(name)
{
var exp = new Date();
exp.setTime(exp.getTime() - 1);
var cval=getCookie(이름);
if(cval!=null)
document.cookie= 이름 + "="+cval+";expires="+exp.toGMTString();
}
//사용 예
setCookie(" name","hayden");
alert(getCookie("name"));
//맞춤 만료 시간을 설정해야 하는 경우
//그런 다음 위의 setCookie 함수를 다음 두 함수로 바꿉니다.
/ /Program code
function setCookie(name,value,time)
{
var strsec = getsec(time);
var exp = new Date();
exp.setTime(exp.getTime() + strsec*1);
문서. 쿠키 = 이름 + "="+ 이스케이프(값) + ";expires=" + exp.toGMTString();
}
function getsec(str)
{
alert(str);
var str1=str.substring (1 ,str.length)*1;
var str2=str.substring(0,1);
if (str2=="s")
{
return str1*1000;
}
else if (str2== "h ")
{
return str1*60*60*1000;
}
else if (str2=="d")
{
return str1*24*60*60*1000;
}
}
// 이것은 만료 시간 설정의 예:
//s20은 20초를 나타냅니다.
//h는 시간을 나타냅니다(예: 12시간): h12
//d는 일 수, 30일: d30
setCookie(" name" ,"헤이든","s20");
封装函数
//获取
function getCookie(c_name){
if (document.cookie.length>0) {
var c_start=document.cookie.indexOf(c_name + "=")
//console.log( c_start);
if(c_start!=-1){
c_start=c_start + c_name.length+1
}else{
return;
}
//username
// console.log(c_start);
c_end=document .cookie.indexOf(";",c_start)
console.log(c_end);
if (c_end==-1) {
c_end=document.cookie.length;
}
return document.cookie.substring(c_start, c_end);
}else{
return ""
}
}
//设置
function setCookie(c_name,value,expiredays){
var exdate=new Date()
exdate.setDate(exdate.getDate()+ expiredays);
document.cookie=c_name+ "=" +value+";"+((expiredays==null) ? "" : ";expires="+exdate.toGMTString())
}
//检查
function checkCookie (){
var username=getCookie('username')
console.log(username);
if (username!=null && username!=""){
Alert('다시 오신 것을 환영합니다 '+username+'!');
//setCookie("username",username,-1);
}else{
username=prompt('이름을 입력하세요:',"")
if (username!=null && username!=""){
setCookie('username',username,365)
}
}
}
onload=checkCookie();
위 내용은 브라우저 저장 기술 쿠키 및 세션의 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!