dnSpy .net 逆向神器
本章将介绍一个调试、逆向.net的神器 dnSpy,将给出一个简单的密码验证示例程序,并完整地介绍如何逆向
安装
可直接使用安装包安装
下载地址
示例程序
编写测试程序 License Test.exe,如果从控制台输出 123456,则显示密码正确,否则密码错误
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace License_Test
{
class Program
{
static void Main(string[] args)
{
while (true)
{
string a = Console.ReadLine();
if (int.Parse(a) == 123456)
{
Console.WriteLine("Password Correct");
}
else
{
Console.WriteLine("Password Wrong");
}
}
}
}
}
逆向
假如忘了密码怎么办?或者这是别人的程序压根不知道密码怎么办?没事我们直接改造它
- 运行程序 License Test.exe
- 启动 dnSpy,注意机器位数要与程序位数对应上,64位使用dnSpy.exe,32位使用dnSpy-x86.exe,并且需要管理员权限,示例程序是32位的
-
[文件]->[打开],找到 License Test.exe 打开,dnSpy 会自动反编译,可以直接打开反编译后的源码
-
在源码上右键修改,改成如下代码(右键可以看到断点等其他调试功能,可以像VS等IDE一样调试)
-
重新编译后,[文件]->[全部保存] 保存成新的可执行文件(可以看到重新编译后注释的代码全部被优化掉了)
-
运行逆向修改后的程序 License No Need.exe
写在后面
奉劝一句,不要拿逆向做坏事~
版权声明:本文为Raito__原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。