C++/Qt中一个简单的加密解密程序

13 篇文章 0 订阅
本例采用查表法实现加密解密,采用一个长度为256的字节数组,每一个对应一个assic码,将顺序打乱,最终是一个全排列,加密的种类有256!=8.5781777534284265411908227168123e+506种,直接上代码吧。

生成密码表的函数,应用之前,先随机生成一个密码表:
QVector
    
    
     
      tmp;
qsrand(QTime(0,0,0).secsTo(QTime::currentTime()));
while(tmp.count()<256)
{
  char t=qrand();
  if(!tmp.contains(t))tmp.append(t);
}


WriteLog_(" const char data[256] = {");
for(int i=0;i
     
     
      
      = 10000000)file.remove();
    file.open(QIODevice::WriteOnly | QIODevice::Append);
    QTextStream text_stream(&file);
    text_stream << message ;
    file.flush();
    file.close();
}
*/

     
     
    
    


在头文件中加入生成的密码表和相关函数的声明:
 const char data[256]= {-12,57,-104,-66,-29,-5,121,124,-85,106,123,-53,2,-37,4,-35,113,-71,-106,-65,-10,
                        -83,34,-27,101,-8,-4,-48,-22,-113,-75,51,90,-79,60,22,-123,-13,99,25,87,42,-47,-26,-100,
                        -122,-46,64,13,102,75,93,69,19,92,-45,39,-16,-103,-80,9,82,88,71,52,-70,7,-14,108,-17,73,
                        65,-57,-90,-60,-23,-20,-67,40,-1,-43,-63,96,86,78,10,97,-84,61,62,-112,14,37,11,-124,-117,
                        85,72,21,127,-39,-118,45,80,53,38,-89,84,-81,-88,17,41,-119,70,18,-36,126,83,-56,76,0,114,
                        -78,48,-44,-54,79,104,112,59,8,-99,35,-114,68,115,31,-28,-24,-49,116,6,103,-51,111,-128,-7,
                        95,-50,77,-33,-97,-93,81,125,-98,-2,43,-31,15,-11,-69,-52,12,-76,28,-3,67,74,-82,-61,-102,
                        -38,109,-101,-116,-121,98,47,-109,-125,-18,36,-62,44,33,-30,29,-9,-110,-34,100,-72,50,3,
                        -68,-42,55,-92,23,-105,-32,56,110,24,-25,16,-96,-58,30,49,-87,-120,-55,-94,-15,119,20,58,32,
                        -41,-91,118,-127,-19,94,107,46,5,117,27,-77,105,120,54,-108,-126,-6,63,26,-64,122,-107,66,
                        -86,-111,-40,91,-95,89,-74,-115,-73,1,-59,-21};

    QMap
    
    
     
      tableEncrypt;
    QMap
     
     
      
       tableDecrypt;

    void encryptFile(QString fileName, QString dest);
    void decryptFile(QString fileName, QString dest);
     
     
    
    

在源文件中加入:

首先初始化密码表:
    for(int i=0;i<256;i++){
        tableEncrypt.insert(i,data[i]);
        tableDecrypt.insert(data[i],i);
    }


加密解密函数:
void MainWindow::encryptFile(QString fileName,QString dest)
{
    QFile *file = new QFile(fileName);
    file->open(QIODevice::ReadOnly);
    QByteArray bytes=file->readAll();

    QByteArray newBytes;
    int cnt=bytes.count();
    newBytes.resize(cnt);
    for(int i=0;i
    
        ui->pushButton->setText("加密");
    connect(ui->pushButton,&QPushButton::clicked,this,[this](){
        QStringList fileNames=QFileDialog::getOpenFileNames();
        QString dest=QFileDialog::getExistingDirectory(this,"选择目标文件夹");
        for(int i=0;i
     
     
      
      pushButton1->setText("解密");
    connect(ui->pushButton1,&QPushButton::clicked,this,[this](){
        QStringList fileNames=QFileDialog::getOpenFileNames();
        QString dest=QFileDialog::getExistingDirectory(this,"选择目标文件夹");
        for(int i=0;i
      
      
     
     


### 回答1: Qt是一种流行的跨平台C++ 应用程序开发框架,它内置了用于数据加密和解密的功能。Qt提供了很多用于加密和解密数据的函数,例如QCA和QCryptographicHash库。 QCA是Qt加密库最常用的库之一,它提供了多个加密算法、哈希算法、公钥和私钥加密算法以及证书管理功能,从而使Qt应用程序能够支持安全地处理和存储数据。在使用QCA的加密和解密功能时,用户可以选择使用对称加密、非对称加密或混合加密的算法。QCA提供的哈希算法可用于生成文件或文本的消息摘要,而加密和解密算法可用于数据加密、解密和文件签名。 QCryptographicHash库是Qt一种基于哈希的加密库,它提供了哈希算法和加密功能,例如MD5和SHA1。QCryptographicHash库可以将任何长度的二进制数据转换为固定长度的哈希值,这可以用于生成密码、数字签名和验证文件完整性。 总之,Qt对数据加密和解密功能的支持对于需要安全地处理和存储数据的应用程序是非常有用的。通过使用Qt提供的加密和哈希库,开发人员可以轻松地实现应用程序的数据加密和解密功能,从而保护用户和应用程序数据的安全。 ### 回答2: Qt一个流行的跨平台图形界面程序开发框架,它提供了许多良好的工具和库,用于开发高质量的C++应用程序Qt可以被用于各种场合,包括桌面应用程序、嵌入式系统和移动设备。Qt提供了许多加密解密的工具和库,用于保护机密信息和数据的安全性。这些工具和库能够轻松地对数据进行加密解密,从而确保数据的完整性和保密性。 Qt使用强大的加密算法和技术,在保护数据的同时确保快速性和效率。Qt提供了一些实用的加密算法,如DES、AES等,这些算法能够有效地保护数据。Qt提供了API调用,可以轻松地对数据进行加密和解密。 Qt还提供了一些有用的功能,用于管理密钥、密码和其他机密信息。Qt提供了一个钥匙链,用于存储机密信息的安全方式。Qt还可以轻松地集成到您的应用程序,从而提供完整的数据保护方案。 在Qt,加密和解密通常使用加密流程。加密程序为原始数据生成随机数,然后将其与原始数据合并,生成一个新的数据块。然后,该数据块被加密并存储在数据库或传输给接收器。在接收器端,解密程序从加密的数据块提取随机数和原始数据,并将它们合并以重建原始数据。 总而言之,Qt提供了一整套的加密解密工具和库,这些工具可以轻松地用于您的应用程序Qt的加密算法和技术能够确保数据的完整性和保密性,从而提供全面的数据保护方案,使您的数据更加安全和可靠。 ### 回答3: Qt一个开源跨平台的C++应用程序开发框架,它提供了一系列的加密和解密API,可以用于各种数据的加密和解密操作。Qt主要提供了以下四种加密和解密算法: 1. 对称加密算法:这种算法将消息加密为一串随机的字节流,并且在解密时使用相同的密钥解密。常见的对称加密算法有AES(Advanced Encryption Standard)、DES(Data Encryption Standard)和RC4(Rivest Cipher 4)等。Qt提供了QAESEncryption和QDES类实现这种算法。 2. 非对称加密算法:这种算法使用两个密钥,一个公钥和一个私钥,来进行加密和解密。在非对称加密,公钥进行加密,而私钥进行解密,相应地,私钥进行签名,公钥进行验证。常见的非对称加密算法有RSA(Rivest, Shamir, Adleman)和DSA(Digital Signature Algorithm)等。Qt提供了QAsymmetricEncryption RSA类实现这种算法。 3. 哈希算法:这种算法使用一种函数将任意长度的消息映射为较短的固定长度的消息摘要。常见的哈希算法有MD5(Message Digest 5)和SHA(Secure Hash Algorithm)等。Qt提供了QCryptographicHash类实现这种算法。 4. 数字签名算法:这种算法使用非对称加密算法对消息进行加密,同时也用随机数和时间戳等信息加上私钥进行签名,以防止伪造。常见的数字签名算法有RSA和DSA等。Qt提供了QSslCertificate和QSslKey类实现这种算法。 总之,Qt在数据加密和解密方面提供了很多优秀的API和类,可以满足不同应用的需求,并且具有较高的安全性和灵活性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值