>  기사  >  백엔드 개발  >  PHP 세션 33개

PHP 세션 33개

WBOY
WBOY원래의
2016-07-30 13:29:401109검색

PHP 세션 변수는 사용자 세션에 대한 정보를 저장하거나 사용자 세션에 대한 설정을 변경하는 데 사용됩니다. 세션 변수가 보유하는 정보는 단일 사용자이며 애플리케이션의 모든 페이지에서 사용할 수 있습니다.


PHP 세션 변수
응용 프로그램을 실행할 때 응용 프로그램을 열고 변경한 다음 닫습니다. 그것은 세션과 매우 유사합니다. 컴퓨터는 당신이 누구인지 알고 있습니다. 애플리케이션을 시작할 때와 종료할 때를 알고 있습니다. 그러나 인터넷에는 문제가 있습니다. 서버는 귀하가 누구인지, 무엇을 하는지 알지 못합니다. 그 이유는 HTTP 주소가 상태를 유지하지 않기 때문입니다.
PHP 세션은 이후 사용을 위해 사용자 정보(예: 사용자 이름, 구매한 항목 등)를 서버에 저장하여 이 문제를 해결합니다. 단, 세션 정보는 일시적이므로 사용자가 사이트를 떠난 후에는 삭제됩니다. 정보를 영구적으로 저장해야 하는 경우 데이터를 데이터베이스에 저장할 수 있습니다.
세션의 작동 메커니즘은 각 방문자에 대한 고유 ID(UID)를 생성하고 이 UID를 기반으로 변수를 저장하는 것입니다. UID는 쿠키에 저장되거나 URL을 통해 전달됩니다.


PHP 세션 시작
PHP 세션에 사용자 정보를 저장하려면 먼저 세션을 시작해야 합니다.
참고: session_start() 함수는 < html> 태그 앞에 배치되어야 합니다.

<code><span><span><?php</span> session_start(); <span>?></span></span><span><<span>html</span>></span><span><<span>body</span>></span><span></<span>body</span>></span><span></<span>html</span>></span></code>

위 코드는 사용자 정보 저장을 시작하고 사용자를 할당할 수 있도록 서버에 사용자 세션을 등록합니다. 세션 UID.


세션 변수 저장
세션 변수를 저장하고 검색하는 올바른 방법은 PHP $_SESSION 변수를 사용하는 것입니다:

<code><span><span><?php</span>
session_start();
<span>// store session data</span><span>$_SESSION</span>[<span>'views'</span>]=<span>1</span>;
<span>?></span></span><span><<span>html</span>></span><span><<span>body</span>></span><span><span><?php</span><span>//retrieve session data</span><span>echo</span><span>"Pageviews="</span>. <span>$_SESSION</span>[<span>'views'</span>];
<span>?></span></span><span></<span>body</span>></span><span></<span>html</span>></span>
输出:
Pageviews=1</code>
<code>在下面的例子中,我们创建了一个简单的 page-view 计数器。<span>isset</span>() 函数检测是否已设置 <span>"views"</span> 变量。如果已设置 <span>"views"</span> 变量,我们累加计数器。如果 <span>"views"</span> 不存在,则我们创建 <span>"views"</span> 变量,并把它设置为 <span>1</span>:
<span><?php</span>
session_start();

<span>if</span>(<span>isset</span>(<span>$_SESSION</span>[<span>'views'</span>]))
  <span>$_SESSION</span>[<span>'views'</span>]=<span>$_SESSION</span>[<span>'views'</span>]+<span>1</span>;

<span>else</span><span>$_SESSION</span>[<span>'views'</span>]=<span>1</span>;
<span>echo</span><span>"Views="</span>. <span>$_SESSION</span>[<span>'views'</span>];
<span>?></span></code>

세션 종료
일부 세션 데이터를 삭제하려면 unset() 또는 session_destroy() 함수를 사용할 수 있습니다.
unset() 함수는 지정된 세션 변수를 해제하는 데 사용됩니다:

<code><span><span><?php</span><span>unset</span>(<span>$_SESSION</span>[<span>'views'</span>]);
<span>?></span></span>
您也可以通过 session_destroy() 函数彻底终结 session:
<span><span><?php</span>
session_destroy();
<span>?></span></span>
注释:session_destroy() 将重置 session,您将失去所有已存储的 session 数据。</code>

쿠키와 세션의 차이점:

특히 쿠키 메커니즘은 유지되는 상태를 사용합니다. 클라이언트 솔루션에서는 세션 메커니즘이 서버 측에서 상태를 유지하는 솔루션을 채택합니다. 동시에 우리는 서버 측에서 상태를 유지하는 솔루션도 클라이언트 측에서 ID를 저장해야 하므로 세션 메커니즘은 ID 저장 목적을 달성하기 위해 쿠키 메커니즘을 사용해야 할 수도 있음을 확인했습니다. 하지만 실제로는 다른 옵션도 있습니다.

<code>cookie机制。正统的cookie分发是通过扩展HTTP协议来实现的,服务器通过在HTTP的响应头中加上一行特殊的指示以提示浏览器按照指示生成相应的cookie。然而纯粹的客户端脚本如JavaScript或者VBScript也可以生成cookie。而cookie的使用是由浏览器按照一定的原则在后台自动发送给服务器的。浏览器检查所有存储的cookie,如果某个cookie所声明的作用范围大于等于将要请求的资源所在的位置,则把该cookie附在请求资源的HTTP请求头上发送给服务器。
cookie的内容主要包括:名字,值,过期时间,路径和域。路径与域一起构成cookie的作用范围。若不设置过期时间,则表示这个cookie的生命期为浏览器会话期间,关闭浏览器窗口,cookie就消失。这种生命期为浏览器会话期的cookie被称为会话cookie。会话cookie一般不存储在硬盘上而是保存在内存里,当然这种行为并不是规范规定的。若设置了过期时间,浏览器就会把cookie保存到硬盘上,关闭后再次打开浏览器,这些cookie仍然有效直到超过设定的过期时间。存储在硬盘上的cookie可以在不同的浏览器进程间共享,比如两个IE窗口。而对于保存在内存里的cookie,不同的浏览器有不同的处理方式
session机制。session机制是一种服务器端的机制,服务器使用一种类似于散列表的结构(也可能就是使用散列表)来保存信息。

当程序需要为某个客户端的请求创建一个session时,服务器首先检查这个客户端的请求里是否已包含了一个session标识(称为session id),如果已包含则说明以前已经为此客户端创建过session,服务器就按照session id把这个session检索出来使用(检索不到,会新建一个),如果客户端请求不包含session id,则为此客户端创建一个session并且生成一个与此session相关联的session id,session id的值应该是一个既不会重复,又不容易被找到规律以仿造的字符串,这个session id将被在本次响应中返回给客户端保存。
保存这个session id的方式可以采用cookie,这样在交互过程中浏览器可以自动的按照规则把这个标识发挥给服务器。一般这个cookie的名字都是类似于SEEESIONID。但cookie可以被人为的禁止,则必须有其他机制以便在cookie被禁止时仍然能够把session id传递回服务器。
经常被使用的一种技术叫做URL重写,就是把session id直接附加在URL路径的后面。还有一种技术叫做表单隐藏字段。就是服务器会自动修改表单,添加一个隐藏字段,以便在表单提交时能够把session id传递回服务器。比如:
 <form name="testform" action="/xxx">
 <input type="hidden" name="jsessionid" value="ByOK3vjFD75aPnrF7C2HmdnV6QZcEbzWoWiBYEnLerjQ99zWpBng!-145788764">
 <input type="text">
 </form>
</code>

사실 이 기술은 액션에 URL 재작성을 적용하여 간단하게 대체할 수 있습니다.

이상으로 관련 내용을 포함하여 33개의 PHP 세션을 소개하였습니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.