91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP系列(十三)PHP會話控制

發布時間:2020-07-31 12:41:11 來源:網絡 閱讀:657 作者:sswqzx 欄目:web開發

php會話控制

一、cookie

1、會話控制之Cookie概述

cookie是在http協議下,服務器或腳本可以維護客戶端信息的一種方式。

Cookie是一種由服務器發送給客戶端的片段信息,存儲在客戶端瀏覽器的內存或者硬盤上。常用于保存用戶名,密碼,個性化設置,個人偏好記錄等。當用戶訪問服務器時,服務器可以設置和訪問cookie的信息。

cookie保存在客戶端,通常是IEFirefox瀏覽器的cookie臨時文件夾中,可以手動刪除。注意:如果瀏覽器上cookie太多,超過了系統所允許范圍,瀏覽器也會自動對它進行刪除

?

2Cookie的操作

設置Cookie

語法:bool setcookie(string name,[string value,[intexpire,[string path,[stringdomain,[intsecure]]]]]);cookie函數可以有6個屬性,常用的有3個參數。

//向客戶端發送一個Cookie,將變量username值為skygao,保存客戶端一周的時間

setcookie("username","skygao", time()+60*60*24*7);

//使用setCookie()函數的全部參數設置

setcookie("username","skygao", time()+60*60*24*7, "/test",".example.com", 1);

setcookie參數解釋

參數描述示例

name 名字調用名為cookienamecookie

value 值假設第一個參為cookiename,通過$_COOKIE[name’取得值]

exprice 有效時間設置cookie的過期時間和日期,用一個標準的Unix時間標記,可以用time()函數取得,以秒為單位.

path 范圍服務器端的有效路徑,設置為“/”表示這個域中所有數組都可以被訪問讀取。

domain 域名設定cookie有效域名

secure 指明cookie只能通過安全的

https傳送設為true時只能使用安全的https,默認為false,即設置是否僅在https安全連接時才發送cookie到客戶端,01

讀取Cookie

如果Cookie設置成功,客戶端就擁有了Cookie文件,用來保存Web服務器為其設置的用戶信息。

PHP中讀取Cookie信息很簡單,使用超全局數組

$_COOKIE[cookie’]即可獲取cookie中的內容。

<?php

//輸出Cookie中保存的所有用戶信息

print_r($_COOKIE);

3Cookie的數組形態應用

數組也可以利用多維數組的形式,將多個內容值存儲在相同Cookie名稱標識符下。

<?php

setcookie("user[username]","skygao"); //$_COOKIE["user"]["username"]

setcookie("user[password]",md5("123456")); //$_COOKIE["user"]["password"]

setcookie("user[email]","skyga@lampbrother.net");//$_COOKIE["user"]["email"]

//遍歷$_COOKIE[user]數組

foreach($_COOKIE["user"]as $key => $value){

//輸出Cookie數組中二維的鍵值對

echo$key.":".$value."\n";

}

?

4、刪除Cookie

2種方式刪除Cookie

1.省略setcookie()函數的所有參數列

2.設置cookie為已過期

<?php

//只指定Cookie識別名稱一個參數,即刪除客戶端中這個指定名稱的Cookie資料

setCookie("account"); //第一種方法

//設置Cookie 在當前時間過期,因此系統會自動刪除識別名稱為isLoginCookie

setCookie("isLogin", "", time()-1); //第二種方法

?

二、session

1、會話控制session的工作機制

SessionCookie相似,都是用來儲存使用者的相關資料。但最大的不同之處在于Cookie是將數據存放在客戶端的計算機之中,而Session則是將數據存放于服務器系統之下。

cookiesessionphp中的使用區別:

cookiesession都可以暫時保存在多個頁面中使用的變量,但是它們有本質的差別。

cookie存放在客戶端瀏覽器中,

session保存在服務器上。

它們之間的聯系是session ID 一般保存在cookie中,或者放在URL上。

禁用cookie的方法:

點擊IE中的“工具”—“Internet選項”,在彈出的對話框里點擊“安全”—“自定義級別”項,將“允許每個對話COOKIE”設為禁用.

?

2session的應用

Session的聲明與使用

Session的設置不同于Cookie,必須先啟動,在PHP中必須調用session_start()

session_start()函數的語法格式如下

Bool session_start(void)

注意:session_start()函數之前不能有任何輸出

Session以數組的形式使用

如:$_SESSION[session名’]

session_start(); //啟動Session 的初始化

$_SESSION["username"]= "skygao"; //注冊Session 變量,賦值為一用戶名稱

$_SESSION["uid"]= 1; //注冊Session 變量,賦值為一個用戶的ID

?

注冊一個會話變量和讀取Session

PHP中使用Session變量,除了要啟動之外,還要經過注冊的過程。注冊和讀取Session變量,都要通過訪問$_SESSION數組完成。

$_SESSION關聯數組中的鍵名具有和PHP中普通變量相同的命名規則。

Session變量會被保存在服務器端的某個文件中,該文件的位置是通過php.ini文件,在session.save_path屬性指定的目錄下。

注銷變量與銷毀Session

1.bool session_destroy(void)

刪除服務器端保留session信息的文件

2.unset($_SESSION[‘鍵名’])

刪除內存中由Session數組保存的變量

清除所有變量可以使用 $_SESSION=array()

3.如果session是基于Cookie的,那么我們還需要刪除客戶端保留的cookie文件

代碼1

<?php

//開啟會話session(cookie不用)

//session_start()前面不能有任何輸出,? 這個函數向客戶端發一個session_id保存在cookie

// 還在服務器中創建一個和保存在客戶端同名的session文件(文本)

???????? session_start();

?

//使用$_SESSION這個數組

???????? $_SESSION['username']="jons";

???????? $_SESSION['age']=18;

???????? $_SESSION['sex']="nv";

???????? $_SESSION['lx']['email']="mz@aaa.com";

???????? $_SESSION['lx']['phone']='119';

?

???????? echo $_SESSION['username'];

代碼2

<?php

//開啟session

// 1. 判斷客戶端是否有了sessionid?變量名為PHPSESSID, 直接使用這個session id開啟會話

// 也不新創建文件了,直接找這個同名session idsession文件

?

???????? session_start();

???????? echo '<br>';

???????? print_r($_SESSION);

???????? echo '<br>';

???????? echo '<br>';

???????? echo $_SESSION['username'];

?

代碼3

<?php

???????? //1開啟會話session? 1

???????? session_start();

?

???????? //多余的

???????? $username= $_SESSION['username'];

?

???????? //unset($_SESSION['username']);

???????? //2就可以刪除數組中的所有內容, session對應的這個用戶文件的內容就空了

???????? $_SESSION= array();

?

???????? //刪除客戶中cookiesessionid

???????? if(isset($_COOKIE[session_name()])){

?????????????????? setCookie(session_name(),"", time()-3600, "/");

?

???????? }

???????? //4銷毀session

???????? session_destroy();

?

???????? echo"再見:{$username}";

?

3Session的配置選項

配置Session

php.ini文件和Session有關的幾個常用配置選項

session.auto_start = 0 ; 在請求啟動時初始化session

session.cache_expire= 180 ; 設置緩存中的會話文檔在 n 分鐘后過時

session.cookie_lifetime = 0 ;設置按秒記的cookie的保存時間,

相當于設置Session的過期時間,為0時表示直到瀏覽器被重啟

session.auto_start=1,這樣就無需每次使用session之前都要調用session_start()。但啟用該選項也有一些限制,如果確實啟用了 session.auto_start,則不能將對象放入會話中,因為類定義必須在啟動會話之前加載以在會話中重建對象。

session.cookie_path = / ; cookie的有效路徑

session.cookie_domain = ; cookie的有效域

session.name =PHPSESSID用在cookie里的session的名字

session.save_handler = files ; 用于保存/取回數據的控制方式

session.save_path= /tmp ; save_handler 設為文件時傳給控制器的參數,這是數據文件將保存的路徑.

session.use_cookies = 1 ; 是否使用cookies

?

4Session的自動垃圾回收機制

php.ini中相關的配置

session.cookie_lifetime=0; 關閉瀏覽器相應的cookie文件即被刪除

session.gc_maxlifetime=1440;設置過期session時間,默認1440秒(24分鐘)

session.gc_probability/session.gc_divisor;啟動垃圾回收機制的概率(建議值為1/10005000

代碼:

//開啟會話session(cookie不用)

//session_start()前面不能有任何輸出,? 這個函數向客戶端發一個session_id保存在cookie

// 還在服務器中創建一個和保存在客戶端同名的session文件(文本)

// 調度PHP的機制使用session

?

???????? session_start();

?

//使用$_SESSION這個數組

?

???????? $_SESSION['username']="jons";

???????? $_SESSION['age']=18;

???????? $_SESSION['sex']="nv";

???????? $_SESSION['aaaaaaaa']="bbbbbbbbbbbbbbb";

???????? $_SESSION['lx']['email']="mz@aaa.com";

???????? $_SESSION['lx']['phone']='119';

?

???????? echosession_name()." = ".session_id()."<br>";

?

5、基于URL傳遞sessionid

為啥要使用URLsession id

基于cookie的方式傳遞session id 這種方式更優。

但不總是可用,因為用戶在客戶端可以屏蔽cokie;

什么是基于urlsession id

是通過url參數進行傳遞

直接將session id嵌入到url中去

參數規則

Session_name()session_id()應用

常量SID的使用

URLsession id也是自動的

在使用Linux系統做服務器時,在編輯PHP時,打開—enable-trans-sid配置選項,和運行時選項session.use_trans_sid=1激活,在客戶端禁用cookie時,相對的url將被自動修改為包含sessionid, 如果沒有配置,或使用windows系統作為服務器時,可以使用常量SID.

建議使用Linux并配置好

<form action=”back.php<?php echo SID ?>” method=”post”>

Name:<input type=”input” name=”username”>

Pass:<input type=”password” name=”pass”>

<input type=”submit” name=”send” value=”登錄”>

</form>

微信掃一掃?、關注公眾號

?? 不定時分享資料視頻

PHP系列(十三)PHP會話控制


?

?


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

邹城市| 博野县| 福建省| 远安县| 楚雄市| 武穴市| 广东省| 彩票| 镇沅| 宁强县| 腾冲县| 泰州市| 藁城市| 迭部县| 昂仁县| 洪湖市| 泾源县| 蒲江县| 金堂县| 林口县| 泸溪县| 吉隆县| 敦煌市| 体育| 德清县| 汤阴县| 祥云县| 徐汇区| 嫩江县| 芮城县| 新宾| 日土县| 新兴县| 龙海市| 天气| 攀枝花市| 竹溪县| 湾仔区| 丰县| 莲花县| 子长县|