前面介绍了cookie和session两种机制的产生和使用过程(能够关注CPP后台服务器公众号查看),可是,彷佛在咱们C++后台开发过程当中碰见的不多;ios
那session在咱们服务端是怎么使用的呢?c++
首先,咱们看一个需求:redis
客户第一次设置登录后,之后再次登录的时候,想要使用快捷登录或者是一键登录,好比咱们使用指纹登录,便可获取咱们的帐户信息数组
方案:安全
说明:bash
用户快捷登录时,根据快捷登录的ID码在redis中查找服务器
若是再redis中不存在,则建立session,与用户的id绑定;若是存在,则登录成功,调用相关功能显示用户信息微信
session的产生通常每一个公司都会有本身改造的一套方案,这样能够提高安全性,这里就使用原生的MD5接口cookie
关于redis键值对的设计,通常都比较简单,建议你们能够本身设计一套,而且实现这个功能;session
这里,简单展现一下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后台服务器开发====
舒适提示
若是你喜欢本文,请分享到朋友圈,想要得到更多信息,请关注我。
扫码关注
更多精彩