修改其exe内部字符串的程序

时间:2009-12-23 18:07:14

标签: c++ visual-studio self-modifying

我正在寻找程序的例子,它修改了其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”)?

3 个答案:

答案 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] = "";
  • 构建我的exe,然后在map文件中查找其段内变量的地址(记住C ++名称的装饰)
  • 解析EXE标头以找到段在exe中开始的位置。
  • 添加这两个数字以获取exe文件中字符串的位置,将此编号提供给我的安装程序
  • 让安装程序运行一个小程序,询问用户信息,然后将其写入.exe。注意:你在exe运行之前已经这样做了,否则它将无效!

答案 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";
    }
 }