阅读 42

Seesion在C++服务端是怎么使用的?

Seesion在C++服务端是怎么使用的?

Snipaste_2020-02-16_17-29-47.png前面介绍了cookie和session两种机制的产生和使用过程(可以关注CPP后台服务器公众号查看),但是,似乎在我们C++后台开发过程中遇见的很少;

那session在我们服务端是怎么使用的呢?

首先,我们看一个需求:

  • 客户第一次设置登陆后,以后再次登陆的时候,想要使用快捷登陆或者是一键登陆,比如我们使用指纹登陆,即可获取我们的账户信息

根据这个需求我们做一个方案进行解决,底层实现我们可以使用session的思想;

方案:

1.png2.png

说明

  • 用户快捷登陆时,根据快捷登陆的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后台服务器开发====

温馨提示

如果你喜欢本文,请分享到朋友圈,想要获得更多信息,请关注我。

扫码关注

更多精彩




关注下面的标签,发现更多相似文章
评论