用session實現的用戶登陸,客戶端是怎樣獲取到cookie信息的

来源:https://www.cnblogs.com/sfriend/archive/2019/06/22/11069764.html
-Advertisement-
Play Games

大家都知道cookie是存在客戶端,session存在伺服器端。那麼客戶端具體是怎樣獲取cookie信息的呢? 原文: http://www.hellomao.top/2019/06/22/two_web_cookie/   作者: 小friend 實驗環境 實驗環境:xampp ...


大家都知道cookie是存在客戶端,session存在伺服器端。那麼客戶端具體是怎樣獲取cookie信息的呢?

更好的閱讀體驗可訪問 這裡

實驗環境

實驗環境:xampp + Thinkphp5 + Firefox

首先清除瀏覽器的cookie緩存和伺服器端的session文件。

  1. Firefox快捷鍵:Ctrl + Shift + Delete 清除瀏覽器cookie緩存信息。
  2. 查看伺服器端的session文件基本也為空。(why.tmp是xampp原本自帶的文件)


註:查看session存放位置的php代碼為:

<?php
//~ 當前session存放位置
$sessionpath = session_save_path();
echo $sessionpath;

現在,瀏覽器既沒有cookie信息,伺服器端也不存在session文件。

獲取過程

在瀏覽器右鍵查看元素,開始訪問搭建的網站。

點擊網路=》點擊要查看的包=》可在響應頭部發現Set-Cookie欄位,也就是這時,伺服器端返回了我們cookie。我們的瀏覽器也就存儲了該cookie信息。以後我們再次訪問該網站時,都會帶著這個cookie信息。

那麼現在伺服器端的session信息是怎麼個情況呢?

可以發現,此時已經生成了很多文件。其中最重要的文件也就是標記的那個,是伺服器為我們生成的session文件(sess_後的內容與伺服器端返回給我們的cookie一致)。但是因為我們還沒有登陸,所以此時文件內容為空,大小為0KB。

然後我們登陸。再次去查看session文件。

發現文件大小已經變為了1KB。其中存儲著我們的登陸信息。(文件的內容與我們具體代碼的實現相關)
以後當我們訪問該網站時,就會在請求頭部帶上cookie信息。像這樣:

然後伺服器端接收到cookie信息,就會去查找session文件的內容,如果發現文件記錄了你已經登陸過,那麼就不用再次登陸

至此,session的作用也就體現了出來。

總結

可以發現session與cookie是密不可分的,任一方出了問題,都不能發揮出它的作用。例如:如果瀏覽器端清除了cookie信息,或者伺服器端的session文件被刪除,那麼就需要重新登陸,重新生成互相匹配的cookie和session才可達到用戶免登陸的效果。同樣,如果瀏覽器端禁用了cookie,該目的也不能達到。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前幾天和朋友閑聊,說遇到了一個ConcurrentHashMap死迴圈問題,當時心裡想這不科學呀?ConcurrentHashMap怎麼還有死迴圈呢,畢竟它已經解決HashMap中rehash中死迴圈問題了,但是隨著深入的分析,發現事情並沒有之前想的那麼簡單~ (以下分析基於jdk版本:jdk1.8 ...
  • set 特點: 無序, 不允許重覆 沒有索引 Collections: Collections 與Collection 的區別: Collection是集合體系的最頂層,包含了集合體系的共性 Collecions是一個工具集,方法都是用於操作Collection map map是具有key和valu ...
  • JFrame的常用構造函數: JFrame() JFrame(String title) //視窗標題,會顯示在左上角窗體圖標的後面 JDialog的常用構造函數: JDialog() JDialog(JFrame/JDialog owner) //指定此對話框的所有者,當此對話框的所有者被關閉/最 ...
  • 信號量(semaphore),也和互斥鎖一樣提供了線程間或者進程間的同步功能。 信號量有三種: "Posix有名字的信號量" Posix基於記憶體的信號量 System V信號量 信號量比互斥鎖高級,互斥鎖只允許一個線程訪問臨界區,信號量可以多個,可以把信號量看作成互斥鎖的升級版,但是如果能用互斥鎖解 ...
  • ImageIcon是Icon介面的一個實現類。 ImageIcon類的構造函數: ImageIcon() ImageIcon(String filename) //本地圖片文件 ImageIcon(URL location) //網路圖片 ImageIcon(byte[] imageData) Im ...
  • [TOC] Jupyter Jupyter Notebook(此前被稱為 IPython notebook)是一個互動式筆記本。它的本質是一個 Web 應用程式,便於創建和共用文學化程式文檔,支持實時代碼,數學方程,可視化和markdown。用途包括:數據清理和轉換,數值模擬,統計建模,機器學習等等 ...
  • 特點 線程不安全 HashMap、和Hashtable、SynchronizedMap區別: HashMap 線程不安全,可以有null的key值或value值。 hashtable 線程安全,不能有null的key值或value值。 ConcurrentHashMap 線程安全,不能有null的k ...
  • setSize()、setPreferredSize()都可以設置組件的大小,但二者的使用有所不同。 1、setSize()的使用方式 setSize(int width,int height) setSize(Dimension d) 2、setPreferredSize()的使用方式 setSi ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...