更新時間:2021-07-22 來源:黑馬程序員 瀏覽量:
當我們?nèi)メt(yī)院就診時,醫(yī)院都會給就診病人發(fā)放就醫(yī)卡,卡上只有卡號,而沒有其它信息。但病人每次去該醫(yī)院就診時,只要出示就醫(yī)卡,醫(yī)務人員便可根據(jù)卡號查詢到病人的就診信息。Session技術(shù)就好比醫(yī)院發(fā)放給病人的就醫(yī)卡和醫(yī)院為每個病人保留病例檔案的過程。當瀏覽器訪問Web服務器時,Servlet容器就會創(chuàng)建一個Session對象和ID屬性,其中,Session對象就相當于病歷檔案,ID就相當于就醫(yī)卡號。當客戶端后續(xù)訪問服務器時,只要將標識號傳遞給服務器,服務器就能判斷出該請求是哪個客戶端發(fā)送的,從而選擇與之對應的Session對象為其服務。
需要注意的是,由于客戶端需要接收、記錄和回送Session對象的ID,因此,通常情況下,Session是借助Cookie技術(shù)來傳遞ID屬性的。
為了大家更好的理解Session,接下來,以網(wǎng)站購物為例,通過一張圖來描述Session保存用戶信息的原理,具體如圖1所示。
圖1 Session保存用戶信息的過程
在圖1中,用戶甲和乙都調(diào)用buyServlet將商品添加到購物車,調(diào)用payServlet進行商品結(jié)算。由于甲和乙購買商品的過程類似,在此,以用戶甲為例進行詳細說明。當用戶甲訪問購物網(wǎng)站時,服務器為甲創(chuàng)建了一個Session對象(相當于購物車)。當甲將Nokia手機添加到購物車時,Nokia手機的信息便存放到了Session對象中。同時,服務器將Session對象的ID屬性以Cookie (Set-Cookie: JsessionID=111)的形式返回給甲的瀏覽器。當甲完成購物進行結(jié)賬時,需要向服務器發(fā)送結(jié)賬請求,這時,瀏覽器自動在請求消息頭中將Cookie (Cookie: JsessionID=111)信息回送給服務器,服務器根據(jù)ID屬性找到為用戶甲所創(chuàng)建的Session對象,并將Session對象中所存放的Nokia手機信息取出進行結(jié)算。
Cookie、sessionStorage、localStorage的區(qū)別
cookie和session的區(qū)別和用法【Java面試題解析】
黑馬程序員Java高級軟件工程師培訓