- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经能够使用 Ollydbg 修改一个可执行文件来做我想做的事
006D0CFA |. 84DB TEST BL,BL
成为
006D0CFA |. 84DB NOP
而且效果很好。
现在,我想用 C++ 来做。我想我可以使用 WriteProcessMemory,但这不是我想要做的。
我想做的是制作一个 C++ 程序(使用 Qt,我不知道这些信息是否有帮助)来“修补”二进制文件。我想用新指令修改二进制文件。
我试过这样做:
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QFile>
#include <QTextStream>
#include <QtDebug>
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);
QString textCracked = getFileText(FILE_CRACKED);
QString textOriginal = getFileText(FILE_ORIGINAL);
runDiff(textOriginal, textCracked);
}
MainWindow::~MainWindow()
{
delete ui;
}
QString MainWindow::getFileText(QString filename)
{
QFile file(filename + ".exe");
QFile file2(filename + ".txt");
if (!file.open(QIODevice::ReadOnly | QIODevice::Text))
return "";
if (!file2.open(QIODevice::WriteOnly | QIODevice::Text))
return "";
QTextStream in(&file);
QTextStream in2(&file2);
QString line = "";
while (!in.atEnd()) {
line += in.readAll();
in2 << line;
}
file.close();
file2.close();
return line;
}
void MainWindow::runDiff(QString original, QString cracked)
{
qDebug() << "Size : " << original.size();
for(int i = 0 ; i < original.size() ; i++)
{
if(original[i] != cracked[i])
qDebug() << i << ", Original : " << original[i] << " | Cracked : " << cracked[i];
}
}
我有这个输出:
Size : 3324384
2941742 , Original : '\u201e' | Cracked : '\u0090'
2941743 , Original : '\u00db' | Cracked : '\u0090'
我的方法有问题:
提前致谢。我可能忘记了什么,请随时询问更多详情。
最佳答案
在评论中,Nox 澄清说他想编辑一个文件而不是一个过程。这是一个说明如何修补文件的简单项目:
#include <windows.h>
#include <iostream>
#include <fstream>
int main()
{
HANDLE hFile = CreateFile("test.txt", FILE_ALL_ACCESS, FILE_SHARE_READ | FILE_SHARE_DELETE, 0, CREATE_ALWAYS, 0, 0);
CloseHandle(hFile);
std::fstream fs("test.txt", std::ios::in | std::ios::out | std::ios::binary);
fs.write("\x52\x61\x6B\x65\x53\x75\x63\x6B\x73", 10);
std::streampos size = fs.tellg();
char* buffer = new char[size];
fs.seekg(0, std::ios::beg); //change offset here
fs.read(buffer, size);
std::cout << "file says: " << buffer << std::endl;
fs.seekg(0, std::ios::beg);
fs.write("\x52\x61\x6B\x65\x52\x6F\x63\x6B\x73", 10);
std::cout << "file patched!\n";
fs.seekg(0, std::ios::beg);
fs.read(buffer, size);
std::cout << "file says: " << buffer << std::endl;
fs.close();
delete[] buffer;
return 0;
}
解释:
创建文件
以输入输出二进制方式打开文件流
向其中写入一些字节,这些字节代表ASCII“RakeSucks”
tellg()给出流的当前位置,也就是大小
向您展示如何读取文件
我们使用 seekg() 回到开头
如果您想转到特定的文件偏移量进行修补,请将 0 替换为您的偏移量。
我们创建一个缓冲区并使用 read() 读取我们刚刚写入的文本,然后我们将它输出到控制台
然后我们使用 seekg() 返回到文件的开头
我们使用 write() 来用新的字节覆盖我们的原始字节。
再次,我们读取字节并输出“RakeRocks”
关于C++ - 更改另一个文件的 ASM 指令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58559494/
我需要处理来自旧 Mac 时代(旧摩托罗拉 CPU)的文件。字节是大端字节序,所以我有一个函数可以将 Int64 交换为英特尔小端字节序。该函数是 ASM,可在 32 位 CPU 上运行,但不能在 6
1.概述 转载:史上最通俗易懂的ASM教程 一勺思想 We are all in the gutter, but some of us are looking at the stars. (我们都生活
1.概述 转载:ASM 与 Presto 动态代码生成简介 代码生成是很多计算引擎中常用的执行优化技术,比如我们熟悉的 Apache Spark 和 Presto 在表达式等地方就使用到代码生成技术。
我想在 C++ 程序中使用 ASM 调用地址为 774a7fdch 的函数(kernel32.dll 函数) 我正在使用 Visual Studio 2010。 我该怎么做? call 774a7fd
我是否正确转换了它? 原始 VS C++ 版本: _TEB *pTeb = NULL; _asm { mov eax, fs:[0x18];
阅读自howto_add_systemcall "In general, header files for machine architecture independent system calls
在实现无锁数据结构和时序代码时,通常需要抑制编译器的优化。通常人们使用 asm volatile 和 clobber 列表中的 memory 来执行此操作,但有时您只会看到 asm volatile
这个“strcpy”函数的目的是将src的内容复制到dest,结果很好:显示两行“Hello_src”。 #include static inline char * strcpy(char * de
我正在尝试进行一些汇编编码,我从 C 语言调用函数。代码本身运行良好,但我有两个巨大的问题在很长一段时间内无法解决。第一个是语法高亮 - 我安装了两个不同的(当时一个)asm 高亮扩展到 Visual
我正在研究一些类文件分析,并且正在研究使用 ASM 来读取类。在 Javap 中,操作码以及 tagName 和 tagValue 是内联打印的,但在每个 AbstractInsnNode 中,我只看
我正在尝试弄清楚如何将 ASM 中的 DB 变量用于内联 ASM C++ 我有这个 ASM 代码: filename db "C:\imagen.bmp" eti0: mov ah,3dh mov a
这个“strcpy”函数的目的是将src的内容复制到dest,结果很好:显示两行“Hello_src”。 #include static inline char * strcpy(char * de
在 mm/memory.c 中,它包含一个文件: #include tlb.h 是 include/asm-generic/tlb.h或 arch/arm/include/asm/tlb.h ? 最
你好我找到了一个asm代码......它被集成到c++项目中 template T returned; BYTE *tem = buffer; __asm { mov eax, tem
问题:当我运行 @ 命令提示符 >tasm HelloWorld.asm 顺便说一句,我在输入文件名 HelloWorld.asm 时使用 TAB,所以没有错字.我收到这个致命的命令行错误: Turb
尝试通过 eax 从 asm proc 返回一个 long int,后来又尝试通过 dx:ax。两者都不适合我,因为 C printf 打印的数字与所需的 320L 不同。 x.asm: .model
这是 godbolt 生成的代码. 下面是 Visual Studio 在我的 main.asm 文件上生成的相同代码(通过 Project->C/C++->Output Files->Assembl
在构建具有依赖项的 giraph jar 时,我们收到以下警告.. 真的不知道如何解决这些.. 我们已经尝试过了 useProjectArtifact 为 false 和 解压为真 两者似乎都有效 任
我正在使用 gentoo 并尝试编译一个程序来控制并行端口上的位。它的顶部附近有这条线: #include 当我尝试在其上使用 gcc 时,它会产生以下输出: port.c:4:20: error:
(原帖)将 hibernate 依赖项添加到 pom.xml 时显示错误 2011-10-11 10:36:53.710::WARN: failed guiceFilter java.lang.No
我是一名优秀的程序员,十分优秀!