您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關怎么在C++服務端中使用Seesion,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
首先,我們看一個需求:
客戶第一次設置登陸后,以后再次登陸的時候,想要使用快捷登陸或者是一鍵登陸,比如我們使用指紋登陸,即可獲取我們的賬戶信息
根據(jù)這個需求我們做一個方案進行解決,底層實現(xiàn)我們可以使用session的思想;
方案:
說明 :
用戶快捷登陸時,根據(jù)快捷登陸的ID碼在redis中查找
如果再redis中不存在,則創(chuàng)建session,與用戶的id綁定;如果存在,則登陸成功,調(diào)用相關功能顯示用戶信息
session的產(chǎn)生一般每個公司都會有自己改造的一套方案,這樣可以提升安全性,這里就使用原生的MD5接口
關于redis鍵值對的設計,一般都比較簡單,建議大家可以自己設計一套,并且實現(xiàn)這個功能;
這里,簡單展示一下 sessionid 的生成:
#pragma once #include <iostream> #include <openssl/md5.h> #include <string.h> using namespace std; class Md5 { public: Md5(); ~Md5(); bool SetMd5(string data); unsigned char* GetMd5(); private: MD5_CTX ctx; unsigned char outMd5[16]; }; #include "Md5.h" Md5::Md5() { } Md5::~Md5() { } unsigned char* Md5::GetMd5() { //數(shù)組初始化 memset(outMd5,0x00,sizeof(outMd5)); int res = MD5_Final(outMd5,&ctx); if(res != 1) { cout<<"Md5_Final is errpr"<<endl; } return outMd5; } bool Md5::SetMd5(string data) { //初始化Md5 MD5_Init(&ctx); //計算Md5 int res = MD5_Update(&ctx,data.c_str(),5); if(res != 1) { cout<<"Md5_Update is errpr"<<endl; return false; } return true; } #pragma once #include <iostream> #include <stdlib.h> #include <stdio.h> #include "string.h" #include "Md5.h"
using namespace std;
class Session { public: Session(); ~Session(); Session(string UserName,int ID); bool SetId(); int GetId(); bool SetUserName(); string GetUserName(); bool SetSessionId(); bool SetSessionData(); string GetSessionData(); unsigned char* GetSessionId(); private: string name; int id; string SessionData; Md5 md5; }; #include "session.h" Session::Session() { } Session::~Session() { } Session::Session(string UserName,int ID) { this->id = ID; this->name = UserName; } int Session::GetId() { return this->id; } string Session::GetUserName() { return this->name; } bool Session::SetSessionData() { char str[20]; memset(str,0,sizeof(str)); //這里使用name+id的方式,生成最終的sessionid sprintf(str,"%d",GetId()); SessionData = GetUserName()+str; return true; } string Session::GetSessionData() { if(!SessionData.empty()) return SessionData; } unsigned char* Session::GetSessionId() { return md5.GetMd5(); } bool Session::SetSessionId() { bool res = md5.SetMd5(GetSessionData()); if(!res) return false; return true; } #include "session.h" int main() { unsigned char* str = new unsigned char[16]; Session session("test",10); session.SetSessionData(); session.SetSessionId(); str = session.GetSessionId(); for(int i=0;i<16;i++) { printf("%02X",str[i]); } printf("\n"); return 0; } CXX = g++ -std=c++11 CFLAG = -g -lssl -lcrypto target = test OBJ = Md5.cpp main.cpp session.cpp $(target):$(OBJ) $(CXX) -o $@ $^ $(CFLAG) clean: rm -f $(target)
補充知識點:
session原理:
用戶使用瀏覽器第一次向服務器發(fā)送請求,服務器在接受到請求后,調(diào)用對應的 Servlet 進行處理。在處理過程中會給用戶創(chuàng)建一個session 對象,用來存儲用戶請求處理相關的公共數(shù)據(jù),并將此 session 對象的 JSESSIONID 以 Cookie 的形式存儲在瀏覽器中 (臨時存儲,瀏覽器關閉即失效)。用戶在發(fā)起第二次請求及后續(xù)請求時,請求信息中會附帶JSESSIONID,服務器在接收到請求后, 調(diào)用對應的Servlet 進行請求處理,同時根據(jù) JSESSIONID 返回其對應的session 對象。
特點:
由服務器進行創(chuàng)建
每個用戶獨立擁有一個session
默認存儲時間為 30 分鐘作用:
解決了一個用戶的不同請求的數(shù)據(jù)共享問題。
使用:
創(chuàng)建Session 對象
存儲數(shù)據(jù)到session 對象獲取session 對象
獲取數(shù)據(jù)從session 對象
如果獲取session 中不存在的數(shù)據(jù)返回null。
看完上述內(nèi)容,你們對怎么在C++服務端中使用Seesion有進一步的了解嗎?如果還想了解更多知識或者相關內(nèi)容,請關注億速云行業(yè)資訊頻道,感謝大家的支持。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。