Qt笔记-char[]或unsigned char[]转QByteArray时要注意的地方

本文探讨了在处理二进制数据,尤其是涉及加密和解密场景时,直接转换为文本字符串可能导致的数据丢失问题。通过示例说明了在进行QByteArray转换时,必须使用正确的长度以避免数据丢失,确保加解密过程的正确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下面这种都是文本串的形式,就可以直接转了比如这样的:

char test[10240] = "hello Wold";
unsigned char test2[1024] = "123456"; 

这类数据都是文本串的可以直接转出来。没有什么问题:

QByteArray array1(test);
QByteArray array2(test2);

但是,如果char[]和unsigned char[]的存的是二进制就不能这么搞了,比如存储加密数据,这样直接转有很大的可能,数据会丢失,因为存二进制时,很有可能在中间某个字节转成文本是\0。

以加密为例。这里要拿到返回的数组长度,比如这样的:

unsigned char decrypt[10240 * 5]={ '\0' };
int result = RSA_private_decrypt(dataArray.size(), dataArray.toStdString().data(), decrypt, rsa, RSA_PKCS1_PADDING);

这里的result就是加密后的长度,转成QByteArray时就需要用到这个了。

QByteArray retArray((char*)decrypt, result);

如果直接这样:

QByteArray retArray((char*)decrypt);

有极大的可能数据会丢失,造成加解密失败。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT1995

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值