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

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

Snipaste_2020-02-16_17-29-47.png前面介绍了cookie和session两种机制的产生和使用过程(能够关注CPP后台服务器公众号查看),可是,彷佛在咱们C++后台开发过程当中碰见的不多;ios

那session在咱们服务端是怎么使用的呢?c++

首先,咱们看一个需求:redis

  • 客户第一次设置登录后,之后再次登录的时候,想要使用快捷登录或者是一键登录,好比咱们使用指纹登录,便可获取咱们的帐户信息数组

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

方案:安全

1.png2.png

说明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后台服务器开发====

舒适提示

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

扫码关注

更多精彩

相关文章
相关标签/搜索