dnSpy .net 逆向神器

dnSpy .net 逆向神器

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

安装

可直接使用安装包安装 下载地址

示例程序

编写测试程序 License Test.exe,如果从控制台输出 123456,则显示密码正确,否则密码错误
dnSpy .net 逆向神器_第1张图片

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 会自动反编译,可以直接打开反编译后的源码
    dnSpy .net 逆向神器_第2张图片
  4. 在源码上右键修改,改成如下代码(右键可以看到断点等其他调试功能,可以像VS等IDE一样调试)
    dnSpy .net 逆向神器_第3张图片
  5. 重新编译后,[文件]->[全部保存] 保存成新的可执行文件(可以看到重新编译后注释的代码全部被优化掉了)
    dnSpy .net 逆向神器_第4张图片
  6. 运行逆向修改后的程序 License No Need.exe
    dnSpy .net 逆向神器_第5张图片

写在后面

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

你可能感兴趣的:(C#,.NET,调试)