Qt对MAC地址加密写入注册表

1、Qt利用QSetting读写注册表。

Windows的注册表格式分为根键、子键、键、值四种元素。

根键为最起始的计算机(“/”)。

根键下有五大子键。

每个子键下有下属子键、键、值。

键、值以键值对的形式存在,一个键对应一个值。

每个子键可以有0个或多个键值对。

   1.QSettings *reg = newQSettings("HKEY_CURRENT_USER\\Software\\yinhaifan", 

   2.                     QSettings::NativeFormat); 

   3.   reg->setValue("registered",true); 

   4.    delete reg;  

上述1、2代码为创建一个子键。

3代码为创建一个键值对。

  1. QSettings *reg = new QSettings("HKEY_CURRENT_USER\\Software\\yinhaifan",  
  2.                 QSettings::NativeFormat);  
  3. if (reg->value("registered",false).toBool())  
  4. {  
  5.     QMessageBox::information(NULL,"information","registered");  
  6. }  
  7. delete reg;  

上述1、2代码为创建一个子键。(子键存在则指向已存在的子键)。

3代码为判断读取键值对是否成功。

W7下会涉及到修改注册表的管理者权限问题。一个解决办法如下。

所以就以“管理员权限”运行qt creator。在Creator中运行编译后的exe文件,成功的修改了注册表。
   realese时,先生成exe文件。再使用win SDK的mt.exe工具把修改后的manifest打包到exe文件中。这时exe文件会被加上一个盾牌的图标,win7启动它时,会自动弹出确认框,让用户授予管理员权限。

 

 

2、Qt读取本机网卡MAC地址

可使用QNetworkInterface读取本地网卡地址。注意在Qt项目文件pro中写上QT+=network

QString address =QNetworkInterface::allAddresses().first().toString();

QString localHostName =QHostInfo::localHostName();

qDebug() <<"主机名:"<<localHostName<<"MAC地址:"<<address;

QList<QHostAddress> list2 =QNetworkInterface::allAddresses();

foreach (QHostAddress address, list2)

{

   if(address.protocol() == QAbstractSocket::IPv4Protocol)

       //我们使用IPv4地址

       qDebug()<< address.toString();

}

 

3、Qt加密算法

使用QCryptographicHash类

该类中包括MD4, MD5, SHA-1, SHA-224, SHA-256, SHA-384, and SHA-512等加密算法。

1 **********加密开始***********/  

2        QString usernamemd5;  

3        QString pwdmd5;  

4       QByteArray bb;  

5        bb = QCryptographicHash::hash ( password.toAscii(), QCryptographicHash::Md5 );  

6        pwdmd5.append(bb.toHex());  

7        bb = QCryptographicHash::hash(username.toAscii(),QCryptographicHash::Md5);  

8         usernamemd5.append(bb.toHex());  

9 ***********加密结束****************/  

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答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、付费专栏及课程。

余额充值