Это возможно? Зависит ли платформа .NET от метаданных в байт-коде? Я бы хотел, чтобы написанное мной приложение не работало в рефлекторе или аналогичном декомпиляторе .NET.





Я не думаю, что вы можете удалить метаданные, но вы можете запутать свой код, если хотите защитить свой IP.
Dotfuscator предотвратит декомпиляцию вашего кода http://www.preemptive.com/dotfuscator.html
Редактировать: Я должен был упомянуть, что это профессиональная версия, бесплатная версия сообщества поставляется с Visual Studio
Я думаю, вы имеете в виду Манифест сборки:
Every assembly, whether static or dynamic, contains a collection of data that describes how the elements in the assembly relate to each other. The assembly manifest contains this assembly metadata. An assembly manifest contains all the metadata needed to specify the assembly's version requirements and security identity, and all metadata needed to define the scope of the assembly and resolve references to resources and classes.
Одна из наиболее важных особенностей сборок .Net заключается в том, что они представляют собой компоненты с самоописанием, и это обеспечивается манифестом. Так что их удаление каким-то образом нарушит его цель.
Если вы удалите метаданные, фреймворк не сможет загрузить ваш код или выяснить, на какие другие сборки он ссылается, или что-то в этом роде, так что нет, это не очень хорошая идея.
Обфускаторы значительно усложнят `` злоумышленнику '' декомпилировать ваш код, но, в конце концов, если кто-то мотивирован и умен, вы мало что сможете сделать, чтобы его остановить. .NET всегда будет компилироваться до MSIL, а MSIL легче читать, чем необработанный x86. Это лишь один из компромиссов, который вы делаете при использовании .NET.
Не беспокойся об этом. Исходный код apache, linux и всего остального находится в свободном доступе в сети, но он не дает Microsoft большого конкурентного преимущества, не так ли :-)
Это похоже на тот же вопрос, что и:
Как сделать манифест сборки .net приватным?
Смотрите мой ответ там:
Как сделать манифест сборки .net приватным?
«Я думаю, что вы говорите о« запутывании ». В сети есть много статей об этом:
http://en.wikipedia.org/wiki/Obfuscation
«Стандартный» инструмент для обфускации в .NET - это Preemptive Solutions:
http://www.preemptive.com/obfuscator.html
У них есть версия сообщества, которая поставляется с Visual Studio, которую вы можете использовать.
Вы упомянули ILDasm, вы смотрели на .NET Reflector?
http://aisto.com/roeder/dotnet/
Это дает вам еще лучшее представление о том, что люди могут увидеть, если вы выпустите манифест! "
Разве такие решения, как ThinApp от VMware (ранее Thinstall), не помогли бы немного защитить и ваш код? Тем не менее, это идет по очень высокой цене.