Seesion在C++服务端是怎么使用的?
前面介绍了cookie和session两种机制的产生和使用过程(可以关注CPP后台服务器公众号查看),但是,似乎在我们C++后台开发过程中遇见的很少;
那session在我们服务端是怎么使用的呢?
首先,我们看一个需求:
-
客户第一次设置登陆后,以后再次登陆的时候,想要使用快捷登陆或者是一键登陆,比如我们使用指纹登陆,即可获取我们的账户信息
根据这个需求我们做一个方案进行解决,底层实现我们可以使用session的思想;
方案:
说明:
-
用户快捷登陆时,根据快捷登陆的ID码在redis中查找
-
如果再redis中不存在,则创建session,与用户的id绑定;如果存在,则登陆成功,调用相关功能显示用户信息
-
session的产生一般每个公司都会有自己改造的一套方案,这样可以提升安全性,这里就使用原生的MD5接口
关于redis键值对的设计,一般都比较简单,建议大家可以自己设计一套,并且实现这个功能;
这里,简单展示一下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()
{
//数组初始化
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)
想了解学习更多C++后台服务器方面的知识,请关注:微信公众号:====CPP后台服务器开发====
温馨提示
如果你喜欢本文,请分享到朋友圈,想要获得更多信息,请关注我。
扫码关注
更多精彩