Session
PHP的$_SESSION可以存儲當前用戶數據信息,用戶訪問WEB網站的時候,PHP會給每個訪問的用戶創建一個session ID,該ID是唯一ID,保存在客戶機上,而用戶的會話數據是保存到服務端的,PHP可以對每個不同的用戶信息進行存儲,當會話過期后,用戶session信息也會失效。
使用Session,在使用PHP session時,一定要在頁頭加上session_start(),告訴服務器開始使用session了,而且在它之前應該沒有任何輸出,否則會報錯。
1
2
3
4
5
|
<?php session_start(); //PHP 代碼... ?> |
PHP設置與獲取Session
我們可以使用PHP的$_SESSION來設置和獲取Session數據,如:
1
2
3
4
5
6
7
8
9
|
<?php session_start(); //設置一個session值 $_SESSION [ "name" ] = "Hello" ; //將session以數組形式保存 $_SESSION [ "arr" ] = array ( 'name' => 'Hello' , 'url' => 'http://www.helloweba.com' , 'type' => 'website' ); ?> |
一旦儲存了Session數據,我們就可以在網站上使用Session,比如我們在另一個頁面就可以獲取Session數據:
1
2
3
4
5
6
7
8
9
|
<?php session_start(); //獲取保存的Session name echo $_SESSION [ "name" ]; //打印數組session print_r( $_SESSION [ "arr" ]); ?> |
PHP刪除Session
當不再使用Session時,我們可以使用PHP將session數據刪除和清空,方法如下:
1
2
3
|
<?php unset( $_SESSION [ "name" ]); ?> |
如果要清空當前用戶所有的Session信息可以使用以下代碼:
1
2
3
|
<?php session_destroy(); ?> |
Cookie
Cookie是由用戶訪問的網站服務端給當前客戶機上創建的一個臨時文件,用來保存用戶信息,以便用戶下次繼續訪問該網站時,網站服務器能識別用戶信息,常見的Cookie用來保存用戶界面,用戶ID等數據。
PHP設置Cookie
我們可以使用PHP的setcookie()在客戶端創建cookie,這個函數提供主要的三個參數,cookie名稱,值和有效時長。
1
2
3
4
|
<?php $cookie_val = 'Chrome' ; setcookie( "browser" , $cookie_val , time()+3600); ?> |
運行以上代碼,將會創建一個名稱為Chrome的Cookie,并且在客戶端保存1個小時,1小時后該cookie信息失效。
PHP接收Cookie
當Cookie創建后,我們很容易就可以獲取到cookie值,使用PHP的$_COOKIE,用法如下:
1
2
3
4
5
|
<?php if (isset( $_COOKIE [ 'browser' ])) { echo '您的瀏覽器是:' . $_COOKIE [ 'browser' ]; } ?> |
PHP刪除Cookie
如果你想徹底在你的機器上刪除保存的cookie信息,可以使用以下代碼:
1
2
3
|
<?php setcookie( "browser" , "" , time()-3600); ?> |
以上代碼將名稱為browser的cookie清空,并將有效期設置到1小時前,完全清空了cookie信息。
本文從初學者角度考慮,講解了PHP入門級的知識:Session和Cookie的應用,我們不必去深究其原理,只要會用就行。