Qt封装的RSA加解密,AES加解密类
#pragma execution_character_set("utf-8")
#ifndef YCRSA_H
#define YCRSA_H
#include <QDebug>
#ifdef Q_OS_WIN
#include <openssl/rsa.h>
#include <openssl/pem.h>
#include <openssl/err.h>
#include <openssl/aes.h>
#else
#include </usr/local/include/openssl/rsa.h>
#include </usr/local/include/openssl/pem.h>
#include </usr/local/include/openssl/err.h>
#include </usr/local/include/openssl/aes.h>
#endif
// define rsa public key
#define BEGIN_RSA_PUBLIC_KEY "BEGIN RSA PUBLIC KEY"
#define BEGIN_PUBLIC_KEY "BEGIN PUBLIC KEY"
#define KEY_LENGTH 1024 // 密钥长度
class YCRsa
{
public:
static bool createRsaKey (QString& strPublicKey, QString& strPrivateKey);
static QString privateEncryptBase64 (const QString& strClearData, const QString& strPriKey, const QByteArray codec = "");
static QString publicDecryptBase64 (const QString& strDecryptData, const QString& strPubKey, const QByteArray codec = "");
static QString publicEncryptBase64 (const QString& strClearData, const QString& strPubKey, const QByteArray codec = "");
static QString privateDecryptBase64 (const QString& strDecryptData, const QString& strPriKey, const QByteArray codec = "");
static std::string encryptAES( const std::string &password, const std::string &data);
//传入utf8 data
static QString encryptAESBase64( const QString &password, const QString &data);
//data可以传入QByteArray的gbk gb2312等,返回base64
static QString encryptGbkAESBase64( const QString &password, const QByteArray &data);
static std::string decryptAES( const std::string &strPassword, const std::string &strData);
static QString decryptAESBase64( const QString &strPassword, const QString &strData);
//返回的QByteArray做编码转换处理,可以得到对应编码
static QByteArray decryptGbkAESBase64( const QString &strPassword, const QString &strData);
};
#endif // RSA_H