我正在寻找程序的例子,它修改了其exe中的字符串。
我在Windows下使用C ++,Visual Studio。
我在Windows中查找了工作示例,但找不到任何可用的代码。
我需要简单的代码,它会询问用户字符串:
string strTest = "";
(if strTest != "")
{
cout << "Modified: " << strTest << endl;
}
cin >> strText;
代码应该重写:
string strTest = "";
要键入该键入的用户:
string strTest = "SomeStringFromUser";
如何在C ++中修改字符串(从字符串strTest =“”)到字符串,用户输入的内容是什么? (例如strTest =“foo”)?
答案 0 :(得分:15)
当在Windows机器上运行EXE时,exe文件将作为CreateFileMapping
对象保持打开状态,其页面标记为READONLY或COPY_ON_WRITE。
因此,当exe写入自身时,文件不会被修改。它只是创建一个由交换文件支持的新页面。但由于文件保持打开状态,其他任何人都无法打开EXE文件并写入文件。
除了黑客页面保护以关闭COPY_ON_WRITE - 我甚至不确定。我能想到的唯一方法就是在你的exe完成后编写一个运行的小程序并打开.exe文件并写入它。
我必须相信无论你想做什么,都有更好的方法去做。
---后来----
好的,我现在明白了。你正在寻找水印你的exe。这就是事情,在exe开始之前,这在安装程序中很容易做到。但是一旦.exe运行起来就很难了。
这就是我要做的。
const char g_szWatermark[100] = "";
答案 1 :(得分:2)
基于一些开放的,已建立的加密机制的许可方案将成为您最强大的解决方案。使用标准PKI的东西应该比尝试实现自修改代码更简单,更安全。
老实说,有很多公司在R&amp; D上投入大量资金创建版权保护,这些系统在发布后的几天内就会被破解。因此,如果你试图挫败破解者,那么你将面临漫长而艰难的道路。
如果您只想让诚实的人保持诚实,那么使用GUID作为“许可证密钥”的简单在线激活将非常有效。
答案 2 :(得分:0)
这个怎么样:
#include <string>
#include <iostream>
int main()
{
std::string strTest = "";
std::getline(std::cin,strTest);
if (strTest != "")
{
std::cout << "Modified String: " << strTest << "\n";
}
else
{
std::cout << "Not modified\n";
}
}