Skip to content

darthwalsh/dotNetBytes

Repository files navigation

dotNetBytes

Build status

Have you ever wondered what was inside your C# EXE or DLL? Have you ever tried to modify a binary and got some weird CLR exception? dotNetBytes can help.

There are many good .NET disassemblers out there, and there are many good visual explanations of what the pieces of a .NET assembly are. I wanted the best of both worlds, having a tool to create a custom visualization of my assemblies.

Features

  • See a structured view of the PE file header, CLI metadata, and the byte-code
    • look in the Table of Contents on the left
  • See the raw hex codes and ASCII view of the bytes
    • bytes are colored based on grouping and ToC selection
  • Understand little endian numbers, bit flags, and string blobs
    • look though the detail view on the right
  • Errors are listed in red details
  • Relative and absolute addresses are hyperlinked
    • look for the cursor to change

Try It!

https://dotnet.carlwa.com/

Motivation

I was working on a C# assembler and I was frustrated when running the EXE failed with useless errors. Without this app, you might need to resort to reading through the EMCA-335 spec to find the off-by-one error in your metadata tables or op codes.

Contributing

There are many ways to help out!

  • You can try out the app at the website or try cloning it yourself.
  • You can file issues for any problems or questions you run into.
  • You can file issues with any suggestions or features requests you have.
  • You can submit pull requests for any issues or to add testing.

Debugging

To debug everything, the vscode debug task Web/Client runs both in watch mode..

When coding on the frontend, I normally:

Software design

There's two main parts to the app, a C# back-end and a JavaScript frontend.

There are four major parts:

  • Lib/ has the disassembly library, and can be executed on the command line to see a pseudo-YAML view of the nested objects
  • view/ is the web frontend
  • Web/ is a ASP.NET MVC server running Lib, and deployed though docker to https://fly.io.
  • Test/ is a bunch of test cases of different C# and IL features. Please make sure they all pass before you submit a PR.

The interface is the frontend POSTS the assembly, and the back-end returns recursive JSON description of the entire assembly, in this recursive format:

{
  "Name": "SomeUniqueName",
  "Description": "Notes about this node based on the language spec",
  "Value": "A ToString() view of the node\n Can Be multiple lines",
  "Start": 16,
  "End": 32,
  "Ecma": "II.24.2.1",
  "LinkPath": "Path/To/Another/Node",
  "Errors": ["Any problems in the bytes that violate the language spec"],
  "Children": [
    { "Name": "FirstChild", "Description": "" },
    { "Name": "Next Child", "Description": "etc etc" }
  ]
}

Some guarantees about the JSON format:

  • Nodes will not have both Children and a LinkPath
  • A node's Children will have unique Name
  • A node's Children will not have have overlapping [Start, End) ranges
  • An array will be represented with names with string suffix, i.e. {Name:Methods, Children:[ {Name: Method[0], ...}, {Name: Method[1], ...} ]}
  • Apart from container nodes (e.g. arrays) with a single element, a node's Children will be strictly smaller than the node.

Scenarios for full test pass

  • Run both Web and SPA with vscode Web/Client task and with python -m http.server 5500 -d view; click around, upload EXE, modify EXE
  • dotnet test passes

Deploying

Website static file hosting uses Cloudflare Pages.

C# disassembly runs as a serverless function using Google Cloud Functions.

Changes are tested by AppVeyor.

Future work

About

Visual disassembler for .NET assemblies

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages