ollydebug实战-破解验证密码

  • 测试环境

  1. WIN10(64位)
  2. VS2017
  3. ollydebug吾爱破解版
  • 待破解程序
  1. Project1.exe(32位)

  • 打开VS2017的工程查看待破解程序的源码

ollydebug实战-破解验证密码_第1张图片

可以看到,这是一个简单的判断程序。

程序运行时提示输入密码,输入字符串"mima"才能提示"密码正确",否则提示"密码错误"

打开ollydebug吾爱破解版查看程序汇编代码(打开待破解程序后会自动弹出一个什么都不显示的黑控制台),然后查找提示的字符串(插件->中文搜索引擎->搜索ASCII)

ollydebug实战-破解验证密码_第2张图片

出现程序提示的字符串

ollydebug实战-破解验证密码_第3张图片

双击"密码正确",自动弹到对应的汇编代码处。

ollydebug实战-破解验证密码_第4张图片

向上寻溯至je(即jump equal)上面(因为要绕过判断,就得修改判断之前的代码)的cmp处(即compare比较)

双击cmp->然后填入修改后的代码->点击汇编

ollydebug实战-破解验证密码_第5张图片

点击运行按钮

ollydebug实战-破解验证密码_第6张图片

破解步骤已经完成,下面测试破解效果。在弹出的黑色控制台窗口处输入任意字符串,可以看到都提示密码正确

ollydebug实战-破解验证密码_第7张图片

  • 破解中的关键汇编指令
  1. jmp(jump)跳往指定地址执行
  2. cmp(compare)比较
  3. je(jump equal)等于就跳转
  4. jne(jump not equal)不等于就跳转

  • 附上测试所用程序的源码
#include
#include
#include
using namespace std;
int main(void)
{
	char c[20];
	char p[] = "mima";
	printf("请输入密码:\n");
	scanf_s("%s", &c);
	if (!strcmp(c, p))
	{
		printf("密码正确\n");
	}
	else
	{
		printf("密码错误\n");
	}
	_getch();
}

你可能感兴趣的:(ollydebug实战-破解验证密码)