Update README
265
README.md
@ -1,6 +1,23 @@
|
|||||||
# ???
|
# dnSpy
|
||||||
|
|
||||||
dnSpy is a tool to reverse engineer .NET assemblies. It includes a decompiler, a debugger and an assembly editor (and more) and can be easily extended by writing your own extension. It uses [dnlib](https://github.com/0xd4d/dnlib) to read and write assemblies so it can handle obfuscated assemblies (eg. malware) without crashing.
|
dnSpy is a debugger and .NET assembly editor. You can use it to edit and debug assemblies even if you don't have any source code available.
|
||||||
|
|
||||||
|
The following pictures show dnSpy in action. It shows dnSpy editing and debugging a .NET EXE file, not source code.
|
||||||
|
|
||||||
|
![debug-animated](images/debug-animated.gif)
|
||||||
|
|
||||||
|
![edit-code-animated](images/edit-code-animated.gif)
|
||||||
|
|
||||||
|
# Features (see below for more detail)
|
||||||
|
|
||||||
|
- Debug .NET Framework and .NET Core assemblies, no source code required
|
||||||
|
- Edit assemblies in C# or Visual Basic or IL, and edit all metadata
|
||||||
|
- Light and dark themes
|
||||||
|
- Extensible, write your own extension
|
||||||
|
- High DPI support (per-monitor DPI aware)
|
||||||
|
- And much more, see below
|
||||||
|
|
||||||
|
dnSpy uses the ILSpy decompiler engine and the Roslyn (C# / Visual Basic) compiler and many other open source libraries, see below for more info.
|
||||||
|
|
||||||
# Binaries
|
# Binaries
|
||||||
|
|
||||||
@ -10,199 +27,65 @@ Latest build: [![Build status](https://ci.appveyor.com/api/projects/status/616rg
|
|||||||
|
|
||||||
Or build it from source, see the [Wiki](https://github.com/0xd4d/dnSpy/wiki/Building-dnSpy).
|
Or build it from source, see the [Wiki](https://github.com/0xd4d/dnSpy/wiki/Building-dnSpy).
|
||||||
|
|
||||||
# Features
|
# Debugger
|
||||||
|
|
||||||
- Open Source (GPLv3) and Free Forever (:TM:)
|
- Debug .NET Framework and .NET Core assemblies, no source code required
|
||||||
- Assembly Editor
|
- Set breakpoints and step into any assembly
|
||||||
- Use C# or Visual Basic to edit any method, property and event
|
- Locals, watch, autos windows
|
||||||
- Code editor has IntelliSense (code completion, signature help, quick info)
|
- Variables windows supports saving variables (eg. decrypted byte arrays) to disk or view them in the hex editor (memory window)
|
||||||
- Whole classes can be added to assemblies by adding C# and Visual Basic code
|
- Object IDs
|
||||||
- Edit all metadata of types (classes), methods, properties, events, fields
|
- Multiple processes can be debugged at the same time
|
||||||
- Add, remove, rename any type (class), method, property, event, field
|
- Break on module load
|
||||||
- Edit, add, remove .NET resources and save them to disk
|
- Tracepoints and conditional breakpoints
|
||||||
- The IL editor allows editing method bodies at the IL level: IL instructions, locals, exception handlers
|
- Export/import breakpoints and tracepoints
|
||||||
- Debugger
|
- Call stack, threads, modules, processes windows
|
||||||
- Debug any .NET assembly, no source code required
|
- Break on thrown exceptions (1st chance)
|
||||||
- Set breakpoints in any assembly, including framework assemblies, assemblies in the GAC and assemblies existing only in memory
|
- Variables windows support evaluating C# / Visual Basic expressions
|
||||||
- Memory window
|
- Dynamic modules can be debugged (but not dynamic methods due to CLR limitations)
|
||||||
- Output window
|
- Output window logs various debugging events, and it shows timestamps by default :)
|
||||||
- Attach to process
|
- Assemblies that decrypt themselves at runtime can be debugged, dnSpy will use the in-memory image. You can also force dnSpy to always use in-memory images instead of disk files.
|
||||||
- Locals window
|
- Public API, you can write an extension or use the C# Interactive window to control the debugger
|
||||||
- raw contents of locals (eg. decrypted byte arrays) can be saved to disk
|
|
||||||
- Call Stack window
|
# Assembly Editor
|
||||||
- Threads window
|
|
||||||
- Modules window
|
- All metadata can be edited
|
||||||
- Modules (eg. decrypted in-memory modules) can be saved to disk
|
- Edit methods and classes in C# or Visual Basic with IntelliSense, no source code required
|
||||||
- Exception Settings
|
- Add new methods, classes or members in C# or Visual Basic
|
||||||
- Can debug dynamic assemblies
|
- IL editor for low level IL method body editing
|
||||||
- Debugging CoreCLR assemblies is supported
|
- Low level metadata tables can be edited. This uses the hex editor internally.
|
||||||
- Decompile to C#, Visual Basic, IL
|
|
||||||
- Themes: blue, dark, light (and high contrast)
|
# Hex Editor
|
||||||
- Supports smaller screens (eg. laptops)
|
|
||||||
- Line height can be optimized for smaller screens
|
- Click on an address in the decompiled code to go to its IL code in the hex editor
|
||||||
- Blank and non-alphanumeric lines are 75% the normal height
|
- Reverse of above, press F12 in an IL body in the hex editor to go to the decompiled code or other high level representation of the bits. It's great to find out which statement a patch modified.
|
||||||
- No extra spacing between lines (saves 1 vertical pixel per line)
|
- Highlights .NET metadata structures and PE structures
|
||||||
- Menu and toolbar share the same line
|
- Tooltips shows more info about the selected .NET metadata / PE field
|
||||||
- Full screen mode (Shift+Alt+Enter) saves some vertical pixels
|
- Go to position, file, RVA
|
||||||
- High DPI support and per-monitor DPI-aware
|
- Go to .NET metadata token, method body, #Blob / #Strings / #US heap offset or #GUID heap index
|
||||||
- Translated to several languages
|
- Follow references (Ctrl+F12)
|
||||||
- Highly extensible
|
|
||||||
- Write your own extensions and add your own features
|
# Other
|
||||||
- All major features are already extensions (assembly editor, debugger, decompiler)
|
|
||||||
|
- BAML decompiler
|
||||||
|
- Blue, light and dark themes (and a dark high contrast theme)
|
||||||
|
- Bookmarks
|
||||||
|
- C# Interactive window can be used to script dnSpy
|
||||||
|
- Search assemblies for classes, methods, strings etc
|
||||||
|
- Analyze class and method usage, find callers etc
|
||||||
- Multiple tabs and tab groups
|
- Multiple tabs and tab groups
|
||||||
- Your screen is too big? Don't cut it in half, add another vertical tab group and read two classes at once!
|
- References are highlighted, use Tab / Shift+Tab to move to next reference
|
||||||
- The tabs and positions within the text editors are saved when you close dnSpy and restored at startup so you can continue where you left off
|
- Go to entry point and module initializer commands
|
||||||
- Search assemblies
|
- Go to metadata token or metadata row commands
|
||||||
- Search for types (classes), methods, properties, events, fields
|
- Code tooltips (C# and Visual Basic)
|
||||||
- Search for strings or numbers in code
|
- Export to project
|
||||||
- Assembly analyzer
|
|
||||||
- Find usages of types (classes), methods, properties, events, fields
|
|
||||||
- BAML to XAML decompiler
|
|
||||||
- Fast
|
|
||||||
- Highlighted references, keywords
|
|
||||||
- References under the caret are highlighted to make it easier to see all uses of the reference in the code
|
|
||||||
- Tab, Shift+Tab, Ctrl+Shift+Up, Ctrl+Shift+Down moves to the next or previous reference
|
|
||||||
- Alt+Down and Alt+Up moves to the next or previous definition (type (class), method, property, event, field)
|
|
||||||
- Structure visualizer
|
|
||||||
- Vertical guide lines shown between start and end of code blocks
|
|
||||||
- Different colors are used for different blocks, eg. loop, conditional, method, etc
|
|
||||||
- [dnlib](https://github.com/0xd4d/dnlib) is used to read and write assemblies so it can handle obfuscated code (eg. malware) without crashing
|
|
||||||
- Go to commands:
|
|
||||||
- Entry point
|
|
||||||
- Assembly static initialization method (<Module>..cctor)
|
|
||||||
- Any metadata token
|
|
||||||
- Any metadata row
|
|
||||||
- Syntax highlighted tooltips with XML doc comments when hovering over a type (class), method, property, event, field
|
|
||||||
- Methods, properties and events are decompiled in source code order or a custom user-defined order
|
|
||||||
- Source code order means that related methods are usually next to each other, just like the programmer wanted
|
|
||||||
- Background images can be shown in the text editor
|
|
||||||
- Export to project decompiles all selected assemblies and creates a Visual Studio solution
|
|
||||||
- Multiple assemblies can be exported at the same time
|
|
||||||
- Creates a Visual Studio solution (supports VS2005 - VS-latest) and project files
|
|
||||||
- Supports WinForms and WPF classes (creates a code-behind .cs/.vb file and a WinForms .resx / WPF .xaml file)
|
|
||||||
- Converts .NET resources to .resx files
|
|
||||||
- Open from GAC
|
|
||||||
- Command line decompiler
|
|
||||||
- Supports Windows, Linux and Mac
|
|
||||||
- Syntax highlights output to the screen
|
|
||||||
- Scripting with C# REPL
|
|
||||||
- Call public dnSpy methods from scripts
|
|
||||||
- Script the debugger and other extensions
|
|
||||||
- Hex editor
|
|
||||||
- Method tokens and addresses are shown in comments and can be clicked to go to the raw metadata or IL bytes
|
|
||||||
- Metadata editor
|
|
||||||
- Collapse Assembly Explorer nodes command to quickly collapse unused nodes
|
|
||||||
- And more...
|
|
||||||
|
|
||||||
# Picture time!
|
# List of other open source libraries used by dnSpy
|
||||||
|
|
||||||
### Edit any method, property or event in C# or Visual Basic
|
- ILSpy decompiler engine (C# and Visual Basic decompilers)
|
||||||
|
- Roslyn (C# and Visual Basic compilers)
|
||||||
![edit-code](images/edit-code.png)
|
- dnlib (.NET metadata reader/writer which can also read obfuscated assemblies)
|
||||||
|
- VS MEF (Faster MEF equals faster startup)
|
||||||
### Edit any type (class), method, property, event, field
|
- ClrMD (Access to lower level debugging info not provided by the CorDebug API)
|
||||||
|
|
||||||
![edit-method](images/edit-method.png)
|
|
||||||
|
|
||||||
### Add, remove, rename any type (class), method, property, event, field
|
|
||||||
|
|
||||||
![delete-method](images/delete-method.png)
|
|
||||||
|
|
||||||
### Edit, add, remove .NET resources and save them to disk
|
|
||||||
|
|
||||||
![edit-resources](images/edit-resources.png)
|
|
||||||
|
|
||||||
### The IL editor allows editing method bodies at the IL level: IL instructions, locals, exception handlers
|
|
||||||
|
|
||||||
![edit-il1](images/edit-il1.png)
|
|
||||||
|
|
||||||
![edit-il2](images/edit-il2.png)
|
|
||||||
|
|
||||||
### Debug any .NET assembly, no source code required
|
|
||||||
|
|
||||||
![debug1](images/debug1.png)
|
|
||||||
|
|
||||||
### Raw contents of locals (eg. decrypted byte arrays) can be saved to disk
|
|
||||||
|
|
||||||
![debug-save](images/debug-save.png)
|
|
||||||
|
|
||||||
### Optimizations for smaller screens
|
|
||||||
|
|
||||||
![more-vert-space](images/more-vert-space.png)
|
|
||||||
|
|
||||||
### Multiple tabs and tab groups
|
|
||||||
|
|
||||||
![tab-group](images/tab-group.png)
|
|
||||||
|
|
||||||
### Search assemblies
|
|
||||||
|
|
||||||
![search](images/search.png)
|
|
||||||
|
|
||||||
### Assembly analyzer
|
|
||||||
|
|
||||||
![analyzer](images/analyzer.png)
|
|
||||||
|
|
||||||
### Highlighted references, keywords, use Tab, Shift+Tab, Ctrl+Shift+Up, Ctrl+Shift+Down to select next or previous reference or Alt+Up/Down for next definition
|
|
||||||
|
|
||||||
![hilite-keywords](images/hilite-keywords.png)
|
|
||||||
|
|
||||||
![hilite-refs](images/hilite-refs.png)
|
|
||||||
|
|
||||||
### Structure visualizer adds colorized vertical guide lines between braces; loops, try/catch and conditional blocks are shown in different colors
|
|
||||||
|
|
||||||
![structure-visualizer](images/structure-visualizer.png)
|
|
||||||
|
|
||||||
### Structure visualizer is very useful when you're in a method like this:
|
|
||||||
|
|
||||||
![nightmare](images/nightmare.png)
|
|
||||||
|
|
||||||
### Go to: Entry Point, Module Initializer, MD Token, MD Table Row
|
|
||||||
|
|
||||||
![go-to-ep](images/go-to-ep.png)
|
|
||||||
|
|
||||||
![go-to-md-token](images/go-to-md-token.png)
|
|
||||||
|
|
||||||
![go-to-md-table-row](images/go-to-md-table-row.png)
|
|
||||||
|
|
||||||
### Syntax highlighted tooltips with XML doc comments when hovering over a type (class), method, property, event, field
|
|
||||||
|
|
||||||
![tooltip](images/tooltip.png)
|
|
||||||
|
|
||||||
### Background images can be shown in the text editor
|
|
||||||
|
|
||||||
![bgimg1](images/bgimg1.png)
|
|
||||||
|
|
||||||
### Same image with left margin and top margin set to 75%
|
|
||||||
|
|
||||||
![bgimg2](images/bgimg2.png)
|
|
||||||
|
|
||||||
### Export to project decompiles all selected assemblies and creates a Visual Studio solution
|
|
||||||
|
|
||||||
![export-to-project](images/export-to-project.png)
|
|
||||||
|
|
||||||
### Command line decompiler, supports Windows, Linux, Mac
|
|
||||||
|
|
||||||
![console](images/console.png)
|
|
||||||
|
|
||||||
### Scripting with `C#` REPL, control the debugger and other extensions with `C#`
|
|
||||||
|
|
||||||
![scripting](images/scripting.png)
|
|
||||||
|
|
||||||
### Hex editor
|
|
||||||
|
|
||||||
![hexeditor](images/hexeditor.png)
|
|
||||||
|
|
||||||
### Metadata editor, click on a token or press Ctrl+Shift+D
|
|
||||||
|
|
||||||
![md-ed1](images/md-ed1.png)
|
|
||||||
|
|
||||||
![md-ed2](images/md-ed2.png)
|
|
||||||
|
|
||||||
# Want to Contribute?
|
|
||||||
|
|
||||||
Check the [issues](https://github.com/0xd4d/dnSpy/issues) for open issues, especially issues with the [up for grabs](https://github.com/0xd4d/dnSpy/issues?q=is%3Aissue+is%3Aopen+label%3A%22up+for+grabs%22) tag since they should be easier to start with.
|
|
||||||
|
|
||||||
If you send a PR, try to use the same coding style as the current project you're editing.
|
|
||||||
|
|
||||||
# Translating dnSpy
|
# Translating dnSpy
|
||||||
|
|
||||||
|
Before Width: | Height: | Size: 35 KiB |
Before Width: | Height: | Size: 94 KiB |
Before Width: | Height: | Size: 59 KiB |
Before Width: | Height: | Size: 28 KiB |
BIN
images/debug-animated.gif
Normal file
After Width: | Height: | Size: 576 KiB |
Before Width: | Height: | Size: 15 KiB |
Before Width: | Height: | Size: 56 KiB |
Before Width: | Height: | Size: 10 KiB |
BIN
images/edit-code-animated.gif
Normal file
After Width: | Height: | Size: 699 KiB |
Before Width: | Height: | Size: 53 KiB |
Before Width: | Height: | Size: 10 KiB |
Before Width: | Height: | Size: 27 KiB |
Before Width: | Height: | Size: 16 KiB |
Before Width: | Height: | Size: 36 KiB |
Before Width: | Height: | Size: 11 KiB |
Before Width: | Height: | Size: 9.2 KiB |
Before Width: | Height: | Size: 2.5 KiB |
Before Width: | Height: | Size: 2.5 KiB |
Before Width: | Height: | Size: 35 KiB |
Before Width: | Height: | Size: 22 KiB |
Before Width: | Height: | Size: 27 KiB |
Before Width: | Height: | Size: 6.2 KiB |
Before Width: | Height: | Size: 47 KiB |
Before Width: | Height: | Size: 57 KiB |
Before Width: | Height: | Size: 24 KiB |
Before Width: | Height: | Size: 25 KiB |
Before Width: | Height: | Size: 22 KiB |
Before Width: | Height: | Size: 38 KiB |
Before Width: | Height: | Size: 168 KiB |
Before Width: | Height: | Size: 13 KiB |