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

資訊專欄INFORMATION COLUMN

如何自己實現(xiàn)session功能

xushaojieaaa / 1165人閱讀

摘要:字如其意,它的存在就是為了保持會話狀態(tài)。中的讓我們很方便的使用它,但是如果本身不提供這個功能,我們該如何實現(xiàn)呢且聽我慢慢忽悠。

session字如其意,它的存在就是為了保持會話狀態(tài)。PHP中的$_SESSION讓我們很方便的使用它,但是如果PHP本身不提供這個功能,我們該如何實現(xiàn)呢?且聽我慢慢忽悠。
session的實現(xiàn)原理

session本身的實現(xiàn)原理其實很簡單,幾句話就可以說完

用戶首次訪問時生成唯一ID(其實就是PHP中的session_id)

根據(jù)session_id作為唯一標(biāo)示,生成session_id為名稱的文件(儲存session內(nèi)容,當(dāng)然也可以存到redis或者mysql中)

通過cookie下發(fā)session_id到客戶端

用戶再次訪問時會通過cookie將session_id帶上

服務(wù)端通過session_id獲取對應(yīng)的session內(nèi)容(文件、Cache、數(shù)據(jù)庫)

代碼實現(xiàn)

下面是我通過PHP實現(xiàn)的一個簡單的session功能類,用來演示具體的實現(xiàn)過程,只實現(xiàn)了寫和讀功能(沒有考慮會話有效期、并發(fā)等問題)。

/**
 * Session類簡單實現(xiàn)
 * @author zhjx922
 */
class Session
{
    //當(dāng)前sessionId
    private $_sessionId;
    //session的儲存路徑
    private $_sessionPath = "/tmp/session";

    /**
     * 初始化sessionId
     */
    public function __construct()
    {
        if(isset($_COOKIE["PHPSESSID"]) && $this->checkSession($_COOKIE["PHPSESSID"])) {
            $this->_sessionId = $_COOKIE["PHPSESSID"];
        } else {
            $this->_sessionId = uniqid();
            setcookie("PHPSESSID", $this->_sessionId);
        }
    }

    /**
     * 設(shè)置session
     * @param string $key
     * @param mixed $value
     */
    public function setSession($key, $value)
    {
        $sessionInfo = $this->getSessionInfo();
        $sessionInfo[$key] = $value;
        $sessionFile =  "{$this->_sessionPath}/{$this->_sessionId}";
        file_put_contents($sessionFile, serialize($sessionInfo));
    }

    /**
     * 獲取session
     * @param string $key
     * @return mixed
     */
    public function getSession($key)
    {
        return $this->getSessionInfo()[$key];
    }

    /**
     * 獲取當(dāng)前sessionId下的內(nèi)容
     * @return array
     */
    private function getSessionInfo()
    {
        if(!is_dir($this->_sessionPath))
        {
            mkdir($this->_sessionPath);
        }

        $sessionFile =  "{$this->_sessionPath}/{$this->_sessionId}";
        if(is_file($sessionFile)) {
            $contents = file_get_contents($sessionFile);
            return unserialize($contents);
        }
        return [];
    }

    /**
     * 檢查session是否有效
     * @param string $sessionId
     * @return bool
     */
    private function checkSession($sessionId)
    {
        $sessionFile =  "{$this->_sessionPath}/{$sessionId}";
        if(is_file($sessionFile)) {
            return true;
        }

        return false;
    }
}

使用方法如下

$session = new Session();
$session->setSession("a", "b"); //第二次訪問時注釋掉這行,驗證下一行$session->getSession("a")輸出的內(nèi)容是否正確
var_dump($session->getSession("a"));

是不是特別簡單呢?使用每個功能的時候多想一下它是怎么實現(xiàn)的,很多時候能夠讓我們快速定位到問題的所在~

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/29023.html

相關(guān)文章

  • 不用 Spring Security 可否?試試這個小而美的安全框架

    摘要:寫在前面在一款應(yīng)用的整個生命周期,我們都會談及該應(yīng)用的數(shù)據(jù)安全問題。用戶的合法性與數(shù)據(jù)的可見性是數(shù)據(jù)安全中非常重要的一部分。 寫在前面 在一款應(yīng)用的整個生命周期,我們都會談及該應(yīng)用的數(shù)據(jù)安全問題。用戶的合法性與數(shù)據(jù)的可見性是數(shù)據(jù)安全中非常重要的一部分。但是,一方面,不同的應(yīng)用對于數(shù)據(jù)的合法性和可見性要求的維度與粒度都有所區(qū)別;另一方面,以當(dāng)前微服務(wù)、多服務(wù)的架構(gòu)方式,如何共享Sessi...

    toddmark 評論0 收藏0
  • 從koa-session源碼解讀session本質(zhì)

    摘要:前言,又稱為會話控制,存儲特定用戶會話所需的屬性及配置信息。類先看構(gòu)造函數(shù)居然啥屁事都沒干。由此基本得出推斷,并不是服務(wù)器原生支持,而是由服務(wù)程序自己創(chuàng)建管理。類老規(guī)矩,先看構(gòu)造函數(shù)接收了實例傳來和,其他沒有做什么。 前言 Session,又稱為會話控制,存儲特定用戶會話所需的屬性及配置信息。存于服務(wù)器,在整個用戶會話中一直存在。 然而: session 到底是什么? session...

    remcarpediem 評論0 收藏0
  • 如何實現(xiàn)一個Python爬蟲框架

    摘要:這篇文章的題目有點大,但這并不是說我自覺對爬蟲這塊有多大見解,我只不過是想將自己的一些經(jīng)驗付諸于筆,對于如何寫一個爬蟲框架,我想一步一步地結(jié)合具體代碼來講述如何從零開始編寫一個自己的爬蟲框架年到如今,我花精力比較多的一個開源項目算是了,這是 showImg(https://segmentfault.com/img/remote/1460000018513379); 這篇文章的題目有點大...

    feng409 評論0 收藏0

發(fā)表評論

0條評論

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