2

我使用加密狗来保护我的可执行文件。加密狗通过两种方式保护软件:

  1. 在代码内部调用读取/写入加密狗内存(例如存储功能数据),使用加密狗中的算法加密/解密数据。加密密钥只能写。
  2. 加密 EXE 文件并使用加载程序通过加密狗对其进行解密。如果任何调试器(如 softice)正在运行,软件要么终止,要么不启动。

购买许可证会比破解我的软件更便宜,而且这是我唯一的目标。

问题是我不能再序列化了!如果我尝试,我会得到以下异常:

SerializationException
Source = mscorlib
Message = Unable to find assembly 'MyApp, Version=1.0.0.3, Culture=neutral, PublicKeyToken=null'.
TargetSite = System.Reflection.Assembly GetAssembly()
Stack =
    System.Runtime.Serialization.Formatters.Binary.BinaryAssemblyInfo.GetAssembly()
    System.Runtime.Serialization.Formatters.Binary.ObjectReader.GetType(BinaryAssemblyInfo assemblyInfo, String name)
    System.Runtime.Serialization.Formatters.Binary.ObjectMap..ctor(String objectName, String[] memberNames, BinaryTypeEnum[] binaryTypeEnumA, Object[] typeInformationA, Int32[] memberAssemIds, ObjectReader objectReader, Int32 objectId, BinaryAssemblyInfo assemblyInfo, SizedArray assemIdToAssemblyTable)
    System.Runtime.Serialization.Formatters.Binary.__BinaryParser.ReadObjectWithMapTyped(BinaryObjectWithMapTyped record)
    System.Runtime.Serialization.Formatters.Binary.__BinaryParser.ReadObjectWithMapTyped(BinaryHeaderEnum binaryHeaderEnum)
    System.Runtime.Serialization.Formatters.Binary.__BinaryParser.Run()
    System.Runtime.Serialization.Formatters.Binary.ObjectReader.Deserialize(HeaderHandler handler, __BinaryParser serParser, Boolean fCheck, Boolean isCrossAppDomain, IMethodCallMessage methodCallMessage)
    System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.Deserialize(Stream serializationStream, HeaderHandler handler, Boolean fCheck, Boolean isCrossAppDomain, IMethodCallMessage methodCallMessage)

由于数据的性质是持久的,我必须使用二进制序列化。

如何解决这个问题?

4

1 回答 1

0

我在这个问题上投入了大量时间,我找到了一种解决方法,而不是真正的解决方案。

我分享我学到的东西。序列化需要加载生成永久流的程序集,以便准确了解保存数据的结构。对于“黑盒”EXE 加密系统,该程序集不可用。一种可能的解决方案是编写一个自定义的 BynaryFormatter:当然这不值得。

解决方法是将要序列化的类放在未加密的 DLL 中,然后在运行时由加密狗在内存中解密。这个想法源于我发现的类似问题的建议:一个想反序列化应用程序 A 中从应用程序 B 写入的数据。

于 2015-05-07T05:57:33.223 回答