![使用者在瀏覽網(wǎng)頁(yè)時(shí)并不是一直與伺服器保持在連線的狀課件_第1頁(yè)](http://file4.renrendoc.com/view/467d5249da77eb9d70b2cc1021fa84d2/467d5249da77eb9d70b2cc1021fa84d21.gif)
![使用者在瀏覽網(wǎng)頁(yè)時(shí)并不是一直與伺服器保持在連線的狀課件_第2頁(yè)](http://file4.renrendoc.com/view/467d5249da77eb9d70b2cc1021fa84d2/467d5249da77eb9d70b2cc1021fa84d22.gif)
![使用者在瀏覽網(wǎng)頁(yè)時(shí)并不是一直與伺服器保持在連線的狀課件_第3頁(yè)](http://file4.renrendoc.com/view/467d5249da77eb9d70b2cc1021fa84d2/467d5249da77eb9d70b2cc1021fa84d23.gif)
![使用者在瀏覽網(wǎng)頁(yè)時(shí)并不是一直與伺服器保持在連線的狀課件_第4頁(yè)](http://file4.renrendoc.com/view/467d5249da77eb9d70b2cc1021fa84d2/467d5249da77eb9d70b2cc1021fa84d24.gif)
![使用者在瀏覽網(wǎng)頁(yè)時(shí)并不是一直與伺服器保持在連線的狀課件_第5頁(yè)](http://file4.renrendoc.com/view/467d5249da77eb9d70b2cc1021fa84d2/467d5249da77eb9d70b2cc1021fa84d25.gif)
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、COOKIE & SESSIONWeb Service Programming張賢宗COOKIE & SESSIONWeb Service Pr關(guān)於 Cookie 與 Session使用者在瀏覽網(wǎng)頁(yè)時(shí)並不是一直與伺服器保持在連線的狀態(tài)下,事實(shí)上當(dāng)瀏覽者送出需求到伺服器端處理後將結(jié)果回傳顯示,就已經(jīng)結(jié)束與伺服器的連線。當(dāng)需要新資料或是更新顯示內(nèi)容時(shí),都必須重新載入頁(yè)面或是重新送出需求。HTTP 之無(wú)狀態(tài)(Stateless)特性關(guān)於 Cookie 與 Session使用者在瀏覽網(wǎng)頁(yè)時(shí)並不為什麼要使用 Cookie 與 Session?Cookie 與 Session 的存在就是為了要解決網(wǎng)站不能
2、保存狀態(tài)的問(wèn)題。 例如:會(huì)員系統(tǒng)當(dāng)會(huì)員以帳號(hào)密碼登入系統(tǒng)後,程式有兩個(gè)方式來(lái)記住登入會(huì)員的資料: 在登入者的電腦中放入一個(gè)小檔案來(lái)記憶 Cookie 在伺服器的記憶體產(chǎn)生一個(gè)空間來(lái)記憶 Session為什麼要使用 Cookie 與 Session?CookieCookie 簡(jiǎn)介Cookie 是將少量的資料儲(chǔ)存在遠(yuǎn)端的個(gè)人電腦中的技術(shù)。為了安全性的理由使用者可以拒絕伺服器儲(chǔ)存任何資料在個(gè)人電腦中, 包含cookie.2022/10/17Cookie and Session4Cookie 簡(jiǎn)介Cookie 是將少量的資料儲(chǔ)存在遠(yuǎn)端的個(gè)IE Cookie 設(shè)定2022/10/17Cookie and
3、 Session5IE Cookie 設(shè)定2022/10/15Cookie aFirefox Cookie 設(shè)定2022/10/17Cookie and Session6Firefox Cookie 設(shè)定2022/10/15Coo存取Cookie存入Cookie可利用setcookie()函數(shù)注意事項(xiàng):setcookie() 必須在任何輸出(echo, print)及之前,否則Cookie 的設(shè)定都會(huì)失敗。Cookie內(nèi)容設(shè)定必須等到下次讀取網(wǎng)頁(yè)時(shí)才會(huì)看到內(nèi)容的改變。2022/10/17Cookie and Session7存取Cookie存入Cookie可利用setcookie()將資料存進(jìn)
4、 Cookiebool setcookie ( string $name , string $value , int $expire , string $path , string $domain , bool $secure , bool $httponly )2022/10/17Cookie and Session8將資料存進(jìn) Cookiebool setcookie ( 2將資料存進(jìn) Cookie$name$value會(huì)自動(dòng)用 URL Encoding 的方法編碼因?yàn)橘Y料放在 Local 端,安全性問(wèn)題$expire指定 Unix 時(shí)間如果設(shè)定過(guò)去的時(shí)間代表刪除此 Cookie沒(méi)有指定時(shí)
5、間代表視窗結(jié)束便刪除2022/10/17Cookie and Session9將資料存進(jìn) Cookie$name2022/10/15Coo將資料存進(jìn) Cookie$domainCookie 有效的網(wǎng)域不設(shè)定代表只對(duì)目前的伺服器有效如果想對(duì) ?.tw 都有效,可以設(shè)定 .tw$secureCookie 是否僅用在 HTTPS 上$httponly只有使用 http 才可以 access Cookie2022/10/17Cookie and Session10將資料存進(jìn) Cookie$domain2022/10/15C讀取 Cookie$_COOKIE“COOKIE 名稱”2022/10/17Co
6、okie and Session11讀取 Cookie$_COOKIE“COOKIE 名稱”/smallpig/cookie.php2022/10/17Cookie and Session12/smallp取消一個(gè) Cookie把 Cookie 的 Expire 時(shí)間設(shè)定在過(guò)去setcookie(TestCookie,time()-3600);2022/10/17Cookie and Session13取消一個(gè) Cookie把 Cookie 的 Expire 時(shí)SessionSession 將資料寫(xiě)在伺服器端,資料的安全性比較高,但較佔(zhàn)資源。每一個(gè)連線都有一個(gè)獨(dú)立的Session 產(chǎn)生使用者連
7、線進(jìn)網(wǎng)站後,讀取或?qū)懭?Session 中的資料。為了辨識(shí)不同的 Session,每個(gè)Session 都會(huì)有一個(gè)唯一的編號(hào)稱為 Session id。Session id 的產(chǎn)生方式有兩種, 分別是Cookie URL 傳遞2022/10/17Cookie and Session14SessionSession 將資料寫(xiě)在伺服器端,資料的安全啟動(dòng)Session啟動(dòng) session 功能的方式有兩種:php.ini參數(shù)設(shè)定參數(shù) session.auto_start ,將此參數(shù)改為 1。 使用session_start() 函數(shù)較為常用的方式啟動(dòng) session 後,伺服器會(huì)利用本次連線之 ses
8、sion id 前面加上 sess_ ,組合成一個(gè)檔案名稱,用來(lái)存放 session 資料。2022/10/17Cookie and Session15啟動(dòng)Session啟動(dòng) session 功能的方式有兩種:2開(kāi)始與結(jié)束 Sessionstring session_name ( string $name );指定 Session 的名稱,或是取得目前 Session 的名稱bool session_start ( void );開(kāi)始一個(gè) Sessionbool session_destroy ( void );取消系統(tǒng) Session 的資料可是 $_SESSION 資料還沒(méi)有取消2022/
9、10/17Cookie and Session16開(kāi)始與結(jié)束 Sessionstring session_na設(shè)定/取得 Session Name/IDstring session_name ( string $name )string session_id ( string $id )2022/10/17Cookie and Session17設(shè)定/取得 Session Name/IDstring se其實(shí)session_name就是存放在 Browser Cookie 的名字Default: PHPSESSID用來(lái)記錄 SessionID 等相關(guān) Session 資料session_id用
10、來(lái)分辨不同的 session (指不同使用者)一般來(lái)說(shuō),都不用設(shè)定,除非有特殊需求2022/10/17Cookie and Session18其實(shí)session_name2022/10/15Cookie儲(chǔ)存 SESSION 資料並結(jié)束/ 如果需要指定 session name and idsession_start();$_SESSION“DATA”=“xxx”;session_write_close()session_commit()Session 會(huì)在 PHP 結(jié)束自動(dòng)儲(chǔ)存,為了安全起見(jiàn),可以自行使用以上兩個(gè)指令儲(chǔ)存。2022/10/17Cookie and Session19儲(chǔ)存 SES
11、SION 資料並結(jié)束/ 如果需要指定 sessSESSION Example?php/page1.phpsession_start();echoWelcometopage#1;$_SESSIONfavcolor=green;$_SESSIONanimal=cat;$_SESSIONtime=time();/Worksifsessioncookiewasacceptedechopage2;/Ormaybepassalongthesessionid,ifneededechopage2;? 2022/10/17Cookie and Session20SESSION Example?php/page1
12、.SESSION Example?php/page2.phpsession_start();echoWelcometopage#2;echo$_SESSIONfavcolor;/greenecho$_SESSIONanimal;/catechodate(YmdH:i:s,$_SESSIONtime);/YoumaywanttouseSIDhere,likewedidinpage1.phpechopage1;? 2022/10/17Cookie and Session21SESSION Example?php/page2.Session Time Life取消變數(shù)unset(變數(shù)名稱); 建議使
13、用bool session_unregister ( string $name )session_unset();取消所有變數(shù)session_ cache_ expire()session_cache_expire(30); 30 分鐘後 expired2022/10/17Cookie and Session22Session Time Life取消變數(shù)2022/10/1Session 與 CookieCookie 可以被使用者假造Session 相對(duì)較安全,但是對(duì)伺服器可能造成負(fù)擔(dān)敏感資料、認(rèn)證:Session登入、身分認(rèn)證普通記錄:Cookie使用者偏好2022/10/17Cookie a
14、nd Session23Session 與 CookieCookie 可以被使用者假Practice Today設(shè)計(jì)一個(gè)猜數(shù)字遊戲如果存放姓名的 Cookie 不存在讓使用者輸入名稱用 Cookie 存放如果要猜的數(shù)字不存在 Session 內(nèi)產(chǎn)生一個(gè)四位數(shù)數(shù)字,用 SESSION 存放四個(gè)數(shù)字不能重複(務(wù)必檢查)讓使用者猜,猜的次數(shù)也用 SESSION 存放使用者猜中後清除 Session 與 Cookie相關(guān)函數(shù)rand( MIN, MAX );2022/10/17Cookie and Session24Practice Today設(shè)計(jì)一個(gè)猜數(shù)字遊戲2022/10程式流程檢查 Cookie
15、 ,不存在的話,讓使用者輸入檢查 Session,沒(méi)有數(shù)字的話,產(chǎn)生該一數(shù)字、次數(shù)=0使用輸入猜測(cè)的數(shù)字次數(shù)+1, 檢查是否正確錯(cuò)誤回到3正確,清除 Cookie Session,回到 12022/10/17Cookie and Session25程式流程檢查 Cookie ,不存在的話,讓使用者輸入202每一頁(yè) TITLE使用者的姓名猜測(cè)的次數(shù)2022/10/17Cookie and Session26每一頁(yè) TITLE使用者的姓名2022/10/15Cooki你也可以按照猜中的次數(shù)給評(píng)語(yǔ)建立一個(gè)積分表,產(chǎn)生前十名利用一些圖片讓網(wǎng)頁(yè)更美2022/10/17Cookie and Session27你也可以按照猜中的次數(shù)給評(píng)語(yǔ)2022/10/15Cook產(chǎn)生四位數(shù)$n=array(); for( $i=1; $i=4; $i+) $x=rand(0,9); while ( in_array( $x, $n) ) $x=rand(0,9); array_push($n, $x); $_SESSIONNUM=$n0.$n1.$n2.$n3; $_SESSIONCOUNT=1;2022/10/17Cookie and Session28產(chǎn)生四位數(shù)$n=array(); 202
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度交通安全知識(shí)普及與駕駛技能培訓(xùn)合同
- 企業(yè)并購(gòu)居間合同委托書(shū)
- 二零二五年度辦公室勞動(dòng)合同地址確認(rèn)及員工離職補(bǔ)償協(xié)議
- 三農(nóng)田灌溉方案與實(shí)施手冊(cè)
- 汽車維修保養(yǎng)規(guī)范手冊(cè)
- 醫(yī)療器械產(chǎn)品采購(gòu)合同
- 石材購(gòu)銷合同補(bǔ)充合同
- 合作收購(gòu)不良資產(chǎn)協(xié)議
- 人力資源管理勞動(dòng)法律法規(guī)遵守作業(yè)指導(dǎo)書(shū)
- 企業(yè)并購(gòu)交易操作指導(dǎo)書(shū)
- 空調(diào)維保應(yīng)急預(yù)案
- 2023年高考語(yǔ)文全國(guó)乙卷作文范文及導(dǎo)寫(xiě)(解讀+素材+范文)課件版
- 模塊建房施工方案
- 多域聯(lián)合作戰(zhàn)
- 生理產(chǎn)科學(xué)-正常分娩期的護(hù)理(助產(chǎn)學(xué)課件)
- 煤場(chǎng)用車輛倒運(yùn)煤的方案
- PPK計(jì)算模板完整版
- 居民自建房經(jīng)營(yíng)業(yè)態(tài)不超過(guò)三種承諾書(shū)
- 河南省陜州區(qū)王家后鄉(xiāng)滹沱鋁土礦礦產(chǎn)資源開(kāi)采與生態(tài)修復(fù)方案
- 中國(guó)高血壓臨床實(shí)踐指南(2022版)解讀
- 最常用漢字5000個(gè)
評(píng)論
0/150
提交評(píng)論