Seesion在C++服務端的使用方法
前面介紹了cookie和session兩種機制的產生和使用過程(可以關注 CPP后臺服務器 公眾號查看),但是,似乎在我們C++后臺開發(fā)過程中遇見的很少;
那session在我們服務端是怎么使用的呢?
首先,我們看一個需求:
客戶第一次設置登陸后,以后再次登陸的時候,想要使用快捷登陸或者是一鍵登陸,比如我們使用指紋登陸,即可獲取我們的賬戶信息
根據(jù)這個需求我們做一個方案進行解決,底層實現(xiàn)我們可以使用session的思想;

方案:


說明 :
- 用戶快捷登陸時,根據(jù)快捷登陸的ID碼在redis中查找
- 如果再redis中不存在,則創(chuàng)建session,與用戶的id綁定;如果存在,則登陸成功,調用相關功能顯示用戶信息
- session的產生一般每個公司都會有自己改造的一套方案,這樣可以提升安全性,這里就使用原生的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ā)送請求,服務器在接受到請求后,調用對應的 Servlet 進行處理。在處理過程中會給用戶創(chuàng)建一個session 對象,用來存儲用戶請求處理相關的公共數(shù)據(jù),并將此 session 對象的 JSESSIONID 以 Cookie 的形式存儲在瀏覽器中 (臨時存儲,瀏覽器關閉即失效)。用戶在發(fā)起第二次請求及后續(xù)請求時,請求信息中會附帶JSESSIONID,服務器在接收到請求后, 調用對應的Servlet 進行請求處理,同時根據(jù) JSESSIONID 返回其對應的session 對象。
特點:
由服務器進行創(chuàng)建
每個用戶獨立擁有一個session
默認存儲時間為 30 分鐘作用:
解決了一個用戶的不同請求的數(shù)據(jù)共享問題。
使用:
創(chuàng)建Session 對象
存儲數(shù)據(jù)到session 對象獲取session 對象
獲取數(shù)據(jù)從session 對象
如果獲取session 中不存在的數(shù)據(jù)返回null。
總結
到此這篇關于Seesion在C++服務端的使用方法的文章就介紹到這了,更多相關session C++服務端內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解C語言中free()函數(shù)與getpagesize()函數(shù)的使用
這篇文章主要介紹了詳解C語言中free()函數(shù)與getpagesize()函數(shù)的使用,是C語言入門學習中的基礎知識,需要的朋友可以參考下2015-08-08

