欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Laravel中的Sessionid處理機制詳解

 更新時間:2017年09月12日 08:30:25   作者:小談  
這篇文章主要給大家介紹了關于Laravel中Sessionid處理機制的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。

前言

本文主要給大家介紹了關于Laravel中Sessionid處理機制的相關內(nèi)容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。

在 Laravel 的配置文件 config/session.php 中可以設置 Session Cookie Name,比如這個項目中設置名稱為“sns_session”:

/*
|--------------------------------------------------------------------------
| Session Cookie Name
|--------------------------------------------------------------------------
|
| Here you may change the name of the cookie used to identify a session
| instance by ID. The name specified here will get used every time a
| new session cookie is created by the framework for every driver.
|
*/
 
'cookie' => 'sns_session',

我們可以看到刷新頁面,查看 cookie,會發(fā)現(xiàn)一個名稱為 sns_session 的 cookie,名字就是我們自定義的。

這個 sessionid 就是 cookie 和 session 聯(lián)系的橋梁,服務器通過這個 sessionid 判斷來自哪個客戶端的請求。

Laravel 的 sessionid 每次刷新發(fā)生變化

但是,每次刷新頁面,這個 cookie 值都會發(fā)生改變!那么這樣服務器如何保持會話呢?因為你的 sessionid 總是在變。

Laravel 對 cookie 進行加密

我們在 vendor/laravel/framework/src/Illuminate/Session/Store.php 的 save 方法中調(diào)試一下,打印一下這里的調(diào)用棧:

/**
 * {@inheritdoc}
 */
public function save()
{
 $this->addBagDataToSession();
 
 $this->ageFlashData();
 
 $this->handler->write($this->getId(), $this->prepareForStorage(serialize($this->attributes)));
 
 $this->started = false;
 
 dd(debug_backtrace(DEBUG_BACKTRACE_PROVIDE_OBJECT,5));
}

每次刷新頁面,這個 Store 對象的 id 屬性其實是沒有變化的,這個屬性就是 sessionid 這個 cookie 的值。也就是說,sessionid 的值并不是每次發(fā)生變化,而是寫 cookie 的時候,值發(fā)生了變化。

在 vendor/laravel/framework/src/Illuminate/Cookie/Middleware/EncryptCookies.php 中的 encrypt 方法找到了原因,這個中間件對所有 cookie 值進行了加密處理,它被包含在 web 中間件。

protected function encrypt(Response $response)
{
 foreach ($response->headers->getCookies() as $cookie) {
 if ($this->isDisabled($cookie->getName())) {
  continue;
 }
 
 $response->headers->setCookie($this->duplicate(
  $cookie, $this->encrypter->encrypt($cookie->getValue())
 ));
 }
 return $response;
}

而這種加密方式是每次加密的結果都不同,所以表現(xiàn)為 sessionid 的值每次都發(fā)生了變化,而實際上并沒有改變。在需要用到這個 cookie 的時候會被解密回去。

Laravel 框架這樣設計的目的可能是為了防止 session 劫持吧!考慮還是比較全面的!

其他補充知識

原生 PHP 設置 session 名稱

session_name() 函數(shù):

<?php
 
/* 設置會話名稱為 WebsiteID */
 
$previous_name = session_name("WebsiteID");
 
echo "The previous session name was $previous_name<br />";
?>

session_name() 函數(shù)返回當前會話名稱。 如果指定 name 參數(shù), session_name() 函數(shù)會更新會話名稱, 并返回 原來的 會話名稱。

請求開始的時候,會話名稱會被重置并且存儲到 session.name 配置項。 因此,要想設置會話名稱,那么對于每個請求,都需要在 調(diào)用 session_start() 或者 session_register() 函數(shù) 之前調(diào)用 session_name() 函數(shù)。

COOKIE和SESSION的區(qū)別和關系

  • COOKIE保存在客戶端,而SESSION則保存在服務器端
  • 從安全性來講,SESSION的安全性更高
  • 從保存內(nèi)容的類型的角度來講,COOKIE只保存字符串(及能夠自動轉(zhuǎn)換成字符串)
  • 從保存內(nèi)容的大小來看,COOKIE保存的內(nèi)容是有限的,比較小,而SESSION基本上沒有這個限制
  • 從性能的角度來講,用SESSION的話,對服務器的壓力會更大一些
  • SEEION依賴于COOKIE,但如果禁用COOKIE,也可以通過url傳遞

總結

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關文章

  • thinkphp學習筆記之多表查詢

    thinkphp學習筆記之多表查詢

    在學習thinkphp 的過程中,需要對多表進行操作,但是在實際過程中,總是遇到各種問題,所以寫下這篇文章,作為自己的學習歷程
    2014-07-07
  • Laravel框架使用Seeder實現(xiàn)自動填充數(shù)據(jù)功能

    Laravel框架使用Seeder實現(xiàn)自動填充數(shù)據(jù)功能

    這篇文章主要介紹了Laravel框架使用Seeder實現(xiàn)自動填充數(shù)據(jù)功能,結合實例形式分析了Laravel基于Seeder類實現(xiàn)自動填充數(shù)據(jù)的相關操作技巧與注意事項,需要的朋友可以參考下
    2018-06-06
  • 用PHP實現(xiàn)的服務端socket具體實例

    用PHP實現(xiàn)的服務端socket具體實例

    這篇文章主要介紹了用PHP實現(xiàn)的服務端socket具體實例,有對這方面不懂的同學可以參考下
    2021-01-01
  • Laravel 5.5中為響應請求提供的可響應接口詳解

    Laravel 5.5中為響應請求提供的可響應接口詳解

    這篇文章主要給大家介紹了關于Laravel 5.5中為響應請求提供的可響應接口的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-11-11
  • 解析PHP中Exception異常機制

    解析PHP中Exception異常機制

    這篇文章主要介紹了解析PHP中Exception異常機制,本文通過異常的基本使用和一些常用的異常使用案例來解析說明該項概念,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • PHP 9 大緩存技術總結

    PHP 9 大緩存技術總結

    也就是將頁面全部生成html靜態(tài)頁面,用戶訪問時直接訪問的靜態(tài)頁面,而不會去走php服務器解析的流程。此種方式,在CMS系統(tǒng)中比較常見,比如dedecms,下面通過本文給大家分享了php9大緩存技術總結,需要的朋友可以參考下
    2015-09-09
  • YII2框架中添加自定義模塊的方法實例分析

    YII2框架中添加自定義模塊的方法實例分析

    這篇文章主要介紹了YII2框架中添加自定義模塊的方法,結合實例形式分析了YII2添加自定義模塊的原理、步驟、實現(xiàn)方法與操作注意事項,需要的朋友可以參考下
    2020-03-03
  • PHP二維數(shù)組矩形轉(zhuǎn)置實例

    PHP二維數(shù)組矩形轉(zhuǎn)置實例

    下面小編就為大家?guī)硪黄狿HP二維數(shù)組矩形轉(zhuǎn)置實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • PHP實現(xiàn)留言板功能的詳細代碼

    PHP實現(xiàn)留言板功能的詳細代碼

    這篇文章主要為大家詳細介紹了PHP實現(xiàn)留言板功能的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • thinkphp5redis緩存新增方法實例講解

    thinkphp5redis緩存新增方法實例講解

    這篇文章主要介紹了thinkphp5redis緩存新增方法實例講解,redis是項目中最常用的緩存,有正在使用的同學可以看下
    2021-03-03

最新評論