国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

php中的會話機制(1)

Anchorer / 2335人閱讀

摘要:什么是會話機制這個太過抽象,也挺復雜的,只能說一下自己的理解。

①什么是會話機制:

這個太過抽象,也挺復雜的,只能說一下自己的理解。在b/s架構下,會話機制,其實就是服務器(server)和瀏覽器(browser)之間的對話的一種方式!這種對話方式,能夠使得web站點能夠對用戶的行為進行追蹤,在同一個站點下用戶所需的數據實現共享!

②為什么要使用會話機制

歸根到底是由于,b/s的訪問方式是基于http協議的,而http協議本身又是無狀態的,所謂無狀態,就是指服務器端無法區分發起請求的是否是同一個人(有興趣的同學可以自己好好研究一下http的無狀態性)!每次請求都會被當做獨立的請求,并不能將兩次訪問聯系到一起!

③核心設計思想

核心設計思想:允許服務器對同一個客戶端的的連續請求進行跟蹤,對同一個訪問者的請求數據,在多個頁面之間實現共享!

④php中實現會話機制的方法:

1)在兩個頁面(較少頁面之間)通過$_GET或者$_POST數組之間實現數據的共享!
2)使用cookie將用戶的信息存放在客戶端的計算機中,用于保存并不重要的數據
3)通過session將用戶的信息保存在服務器中

通過$_GET和$_POST方式獲得數據較為簡單,這里就不再介紹!


cookie會話機制實現的注意點

1)當我們通過setCookie()函數來新增或者改變cookie中的值的時候,setCookie()函數前面不能夠有任何實際的輸出,即使是空格也不可以!
這是因為setCookie()函數最終是改變http響應頭信息我們有理由相信setCookie()方法,底層就是通過header()方法進行的設置的頭信息,我們都應該知道在header函數前面是不能夠有任何實際的輸出的(除非是開啟了ob緩存)!

2)在cookie中是只能夠保存字符串的,但是,如果我們想將一個數組變量保存到cookie中,在不進行序列化的情況下,其實也是可以辦到的,代碼如下:





> 得到的結果如下:
>     array(3) {
>       [""name""]=>
>           array(2) {
>             [""xing""]=>
>             string(5) "liang"
>             [""ming""]=>
>             string(2) "bo"
>           }
>       [""age""]=>
>       string(2) "23"
>       [""addr""]=>
>       string(6) "吉林"
>     }

3)cookie的$path參數,只有在指定的路徑下的網頁才可以獲取cookie中的值!demo如下:


該頁面所處的路徑"/",也就是網站的根目錄!

接受的代碼如下:


改代碼文件所在的路徑如下:/talkphp/secondtalk/
執行結果如下:string(7) "liangbo"

同樣的接受代碼:但是所處的路徑不同,是在根目錄“/”下,
得到的結果如下:null

4)cookie的跨域問題:
個人認為跨域問題,主要是值存在同一個網站下,有多個二級域名,在多個二級域名下cookie數據的共享問題!
在cookie中,如果設置的domain參數是一級域名的話,那么cookie中的數據在各個二級域名之間是都可用的!demo如下:




該代碼所在的網站域名是:php.test.com 頁面路徑是:/talkphp/secondtalk/getcookie.php
運行結果如下:string(7) "liangbo"

同樣的代碼,該代碼所在的域名是:jquery.test.com 頁面所在的路徑是:/talkphp/secondtalk/getcookie.php
運行結果如下:string(7) "liangbo"
可見,如果domain參數中設置的是一級域名的話,那么在各個二級域名之間$_COOKIE中的數據是可以共享的
在一級域名中.test.com,中test前的"."其實是可以省略的,但是加上的話,瀏覽器的兼容會更好!

我們來看另外一種情況:


這里,我們將domain設置為了二級域名php.test.com


該代碼所在的網站域名是:php.test.com 頁面路徑是:/talkphp/secondtalk/getcookie.php
運行結果如下:string(7) "liangbo"

同樣的代碼,該代碼所在的域名是:jquery.test.com 頁面所在的路徑是:/talkphp/secondtalk/getcookie.php
運行的結果如下:null
可見,如果設置的domain參數是二級域名的話,那么cookie中的數據只能夠在該二級域名下面使用!

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/20701.html

相關文章

  • php中的會話機制(2)

    摘要:會話機制如果是基于的會話機制,在調用之前,是不能夠有任何實際的輸出的,即使是空格或者是空行因為函數調用的時候,其實是通過函數向中設置了這個,對應的是一個隨機的唯一的位字符串而前面是不可以有任何實際的輸出的注意這里的名字是在文件中進行的配置配 session 會話機制: 1)如果是基于cookie的會話機制,在調用session_start()之前,是不能夠有任何實際的輸出的,即使是空...

    ConardLi 評論0 收藏0
  • PHP面試常考之會話控制

    摘要:一的會話也稱為。如果啟動會話成功,則函數返回,否則返回。會話啟動后就可以載入該會話已經注冊的會話變量以便使用。但數組創建的在會話結束后就會失效。預告本周三更新面試常考之網絡協議,敬請期待。 你好,是我琉憶,歡迎您來到PHP面試專欄。本周(2019.2-25至3-1)的一三五更新的文章如下: 周一:PHP面試常考之會話控制周三:PHP面試常考之網絡協議周五:PHP面試常考題之會話控制和...

    lsxiao 評論0 收藏0
  • session和cookie

    摘要:的作用就是為了解決協議無狀態的缺陷所作的努力。的內容主要包括名字,值,過期時間,路徑和域。這種生命期為瀏覽器會話期的被稱為會話。而機制采用的是一種在服務器端保持狀態的解決方案。中的有效期默認分鐘,也就是說,客戶端超過分鐘,當前就會失效。 會話控制是什么? cookie和session都是跟蹤整個會話過程的技術手段。而會話,就是用戶通過瀏覽器和服務器的一次通話。 為什么要有會話控制? 因...

    ruicbAndroid 評論0 收藏0
  • 詳解Session

    摘要:會在腳本執行完畢或調用函數之后調用此回調函數。此回調函數操作成功返回,反之返回。在回調函數中,以傳入的作為,以的值作為中的值存入,并設置過期時間為秒方法以傳入的為從取出相應的的值。 1 Session的基本概念和設置 Session存儲在服務端,本質上和Cookie沒有區別,都是針對http協議的局限性而提出的一種保持客戶端和服務端間會話狀態的機制。Session經常用來網站的上下文間...

    joy968 評論0 收藏0

發表評論

0條評論

Anchorer

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<