dnSpy .net 逆向神器

  • Post author:
  • Post category:其他




dnSpy .net 逆向神器

本章将介绍一个调试、逆向.net的神器 dnSpy,将给出一个简单的密码验证示例程序,并完整地介绍如何逆向



安装

可直接使用安装包安装

下载地址



示例程序

编写测试程序 License Test.exe,如果从控制台输出 123456,则显示密码正确,否则密码错误

License Test.exe 运行结果

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");
                }
            }
        }
    }
}



逆向

假如忘了密码怎么办?或者这是别人的程序压根不知道密码怎么办?没事我们直接改造它

  1. 运行程序 License Test.exe
  2. 启动 dnSpy,注意机器位数要与程序位数对应上,64位使用dnSpy.exe,32位使用dnSpy-x86.exe,并且需要管理员权限,示例程序是32位的
  3. [文件]->[打开],找到 License Test.exe 打开,dnSpy 会自动反编译,可以直接打开反编译后的源码

    定位源码
  4. 在源码上右键修改,改成如下代码(右键可以看到断点等其他调试功能,可以像VS等IDE一样调试)

    修改源码
  5. 重新编译后,[文件]->[全部保存] 保存成新的可执行文件(可以看到重新编译后注释的代码全部被优化掉了)

    重新编译
  6. 运行逆向修改后的程序 License No Need.exe

    License No Need.exe 运行结果



写在后面

奉劝一句,不要拿逆向做坏事~



版权声明:本文为Raito__原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。