草庐IT

c++ - 在 C++ 中隐藏加密 key 的跨平台方式?

我的应用程序需要使用几个硬编码的对称加密key(虽然我知道存储公钥是唯一完美的解决方案,但这是没有商量余地的)。我们希望key被混淆存储,这样它们就不会通过分析可执行文件被识别出来,并尽可能短地“存在”在内存中——以增加执行任务的难度内存转储以明文形式检索它们。我对使用C++功能很感兴趣(想到使用某种scoped_key)。该解决方案必须可移植-Windows、Linux、MacOS,因此它无法利用操作系统加密API。您将如何设计这样一个系统?非常感谢。 最佳答案 在这里,您要做的只是默默无闻的安全性。如果你让我们中的一个人想出一个

c++ - 如何更新特定键的 QHash 值?

我在C++中使用QHash来存储一些简单的键值对。在我的例子中,键是一个整数,值也是。要向散列添加新的键/值对,这是我的语法:QHashmyhash;intkey=5;intvalue=87;myhash.insert(key,value);qDebug()如何更新现有的键值对?语法是什么? 最佳答案 T&QHash::operator[](constKey&key)Returnsthevalueassociatedwiththekeyasamodifiablereference.您可以执行以下操作:myhash[5]=88;根据文

c++ - 为什么 std::map 没有 insert(key &, value & v) 类型的插入函数

为什么std::map不支持如下插入:std::mapmap_int;voidinsert_map(obj1&key,obj2&val){map_int.insert(key,val);}我知道以上是不正确的。我想知道是什么阻止了这样设计插入功能。它比创建一对IMO更直观。 最佳答案 它叫做emplace():std::mapm;//usespair'stemplateconstructorm.emplace("d","ddd"); 关于c++-为什么std::map没有insert(k

c++ - Windows 虚拟键代码

我如何实现像std::stringVirtualKeyCodeToStdString(UCHARkey)这样返回虚拟键描述的函数?示例:输入为VK_CAPITAL,返回值为std::string("CapsLock") 最佳答案 将VK代码转换为key的文本表示的一种简单方法是:使用MapVirtualKey将VK码转换为扫码。进行位移以将该值转换为长整数,其中第16-23位是扫描码使用GetKeyNameText获取key的名称。例如:WCHARname[1024];UINTscanCode=MapVirtualKeyW(VK_C

C++ STL : Why is there no upper_bound equivalent that retrieves the greatest element smaller then a specific key?

通常,STL是为提高速度而构建的。然而,在map和set数据结构上只有upper_bound和lower_bound并且没有操作来检索具有小于输入键的最大键的条目k.为什么是这样?我知道我可以简单地做一个lower_bound并做一个--it检索它,但根据数据结构,立即搜索正确的条目可能比搜索另一个条目然后返回一步更有效。例如,std::map使用红黑树,即二叉搜索树。如果upper_bound返回的元素是大于根的最小元素,则--it必须回到根,查询O(logn)的额外成本。如果这是Java,我会接受设计决定。然而,STL是为实现最高速度而构建的,那么为什么要省略此操作?澄清:我不是在

C++ STL 映射无法识别 key

我有这段代码,CBString只是我用于某些处理的字符串类char*scrummyconfigure::dosub(strtypeinput){CBStringtstring;tstring=input;uintbegin;uintend;begin=tstring.findchr('$');end=tstring.findchr('}',begin);CBStringk=tstring.midstr(begin+2,end-2);//thisisBASEstrtypevname=(strtype)((constunsignedchar*)k);strtypebvar=(strtype

二分查找算法讲解及其C++代码实现

二分查找算法是一种常用的查找算法,也被称为折半查找。它可以在有序的数组或列表中快速查找需要的元素。算法描述:首先确定数组的中间位置mid=(left+right)/2;然后将要查找的值key与中间位置的值进行比较;如果key等于中间位置的值,则查找成功,返回mid;如果key小于中间位置的值,则在左半部分继续查找;如果key大于中间位置的值,则在右半部分继续查找;重复以上步骤,直到查找到key或者left>right时,查找结束。C++代码实现:intbinarySearch(intarr[],intn,intkey){intleft=0;intright=n-1;while(leftkey)

c++ - 编译器无法识别模板函数中的映射迭代器

这个问题在这里已经有了答案:Troublewithdependenttypesintemplates(2个答案)关闭去年。我有以下代码。templateboolhas_key(keychkey,std::mapmap){for(std::map::iteratorit=map.begin();#line13referencedbygccit!=map.end();++it){if(chkey==it->first)returntrue;}returnfalse;}GCC给我以下错误。objects.hpp:Infunction`boolhas_key(key,std::map,std:

c++ - 使用不可导出的私钥和 CryptoAPI 进行解密

我在Windowskeystore中创建了RSAkey对。我成功加密数据(对称key):HCERTSTOREhstore=::CertOpenSystemStore(NULL,L"TestStore");PCCERT_CONTEXTpctxt=::CertFindCertificateInStore(hstore,X509_ASN_ENCODING,NULL,CERT_FIND_SUBJECT_STR,L"MyTestKeys",NULL);HCRYPTPROVhprovider=NULL;if(!::CryptAcquireContext(&hprovider,NULL,MS_ENH

c++ - 如何在 C++ 中隐藏我的 AWS S3 访问 key 和 secret ?

我在我的C++应用程序中使用AWSS3来上传和下载文件。我在我的代码中包含了访问key和secret,但我担心有人可以从二进制文件中读取它们。是否有混淆它们的标准技术?更新:我没有在PC上运行这个应用程序,它实际上是在嵌入式设备上,所以我不担心用户从文件或RAM中读取key和secret(访问设备要困难得多)。我担心的是有人对我们的更新文件进行binwalk并从二进制文件中提取key和secret。 最佳答案 在计算机中存储secret不是一件容易的事。您可以做的一件事是使用密码加密key并将加密数据存储在文件中。然后,当用户输入密