이 글은 주로 PHP에서의 쿠키와 session의 차이점과 쿠키 및 세션 사용 요약에 대한 관련 정보를 소개합니다. 매우 좋고 도움이 필요한 친구들이 참고할 수 있습니다.
구체적으로는, 쿠키는 "클라이언트"에 저장되고 세션은 "서버"에 저장됩니다.
쿠키는 http 프로토콜을 확장하여 구현됩니다.
쿠키에는 주로 이름, 값, 만료 시간, 경로 및 도메인이 포함됩니다.
string
이어야 합니다. . 이 세션 ID는 저장을 위해 이 응답으로 클라이언트에 반환됩니다. 이 세션 ID를 저장하는 방법은 쿠키를 사용하여 상호 작용 프로세스 중에 브라우저가 규칙에 따라 이 ID를 서버에 자동으로 보낼 수 있도록 하는 것입니다. 일반적으로 이 쿠키의 이름은 SEEESIONID와 유사합니다. 그러나 쿠키는 인위적으로 비활성화될 수 있으며 쿠키가 비활성화된 경우 세션 ID를 서버에 다시 전달하는 다른 메커니즘이 있어야 합니다.
1. 쿠키 데이터는 고객의 브라우저에 저장되고, 세션 데이터는 서버에 저장됩니다.
보안을 고려하여 세션을 사용해야 합니다.
3. 세션은 일정 기간 동안 서버에 저장됩니다. 접속량이 증가하면 서버 성능을 더 많이 차지하게 됩니다
서버 성능을 저하시키려면 COOKIE를 사용해야 합니다.
로그인 정보 등 중요한 정보를 SESSION
에 넣을 수 있습니다. 세션 및 쿠키 사용 요약:
세션과 쿠키는 모두 asp.Net에 내장된 개체입니다. 차이점에 대해서는 여기서 자세히 설명하지 않겠습니다.
구성 파일
에 저장하는 것이 좋습니다. 코드는 다음과 같습니다. <sessionState timeout="2" mode="StateServer" />
if (Request.Cookies["httpCookie"] != null) { Session["admin"] = Request.Cookies["httpCookie"].Values["admin"].ToString(); } if (Session["admin"] == null) { this.ClientScript.RegisterStartupScript(this.GetType(), "", "<script>alert('请重新登 录');location.href='logins.aspx'</script>"); }
이제 종료할 때 해야 할 일에 대해 이야기해 보겠습니다.
1. 종료할 때 세션과 쿠키의 값이 지워집니다. 이제 간단히 이야기해 보겠습니다. 여러 세션 방법의 차이점:
Session.clear(): 세션의 모든 세션 키 값이 지워지지만 세션은 여전히 존재함을 나타냅니다. Session.RemoveAll()
Session["admin"]=null과 동일합니다. 키가 지정됩니다. 값이 지워지고 해제됩니다. 이는 session["admin"]=""과 다릅니다. 지워지지만 세션이 해제되지 않습니다. 이는 session.Remove("name");
과 동일합니다.
Session.Abandon()은 현재 Session 객체가 삭제되고, 다음 세션은 새로운 Session이 됩니다.
가장 큰 차이점은 Session.Abandon을 사용할 때 Session_End 메서드(InProc 모드에서)가 호출된다는 것입니다. 다음 요청이 오면 Session_Start 메소드가 실행됩니다. Session.Clear는 세션의 모든 데이터만 지우고 세션을 종료하지 않으므로 해당 메서드는 호출되지 않습니다. Abandon 메서드는 세션 시간이 초과될 때 적극적으로 세션을 종료하는 데 사용됩니다. 또한 현재 세션을 자동으로 종료합니다.
2. 쿠키를 삭제하는 방법을 살펴보겠습니다
A.tpCookie cookie = System.Web.HttpContext.
Current
cookie.Expires = DateTime . Now.AddDays(-1);System.Web.HttpContext.Current.Response.Cookies.Add(cookie);
B, tpCookie httpCookie = Request.Cookies["httpCookie"];
Response.Cookies.Add(httpCookie);
AB 두 가지 방법을 모두 사용할 수 있습니다
3. 세션의 현재 값, 즉 Session["admin]을 삭제하세요. '] =null이면 괜찮으며 위의 방법에 따라 쿠키를 지울 수 있습니다
제안 및 의견:
1 종료할 때 로그아웃 페이지를 만들어 시간을 기록할 수 있어 더 좋습니다
2. 어떤 작업을 수행하더라도 If를 사용하여 비어 있는지 판단할 수 있다면 널 포인터 예외 발생을 방지하기 위해 최선을 다하세요
위 내용은 PHP에서 쿠키와 세션의 차이점과 쿠키와 세션의 사용법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!