| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- using System;
- using System.IO;
- using System.Runtime.Serialization;
- using System.Runtime.Serialization.Formatters.Binary;
- namespace Abp.Runtime.Serialization
- {
- /// <summary>
- /// This class is used to simplify serialization/deserialization operations.
- /// Uses .NET binary serialization.
- /// </summary>
- public static class BinarySerializationHelper
- {
- /// <summary>
- /// Serializes an object and returns as a byte array.
- /// </summary>
- /// <param name="obj">object to be serialized</param>
- /// <returns>bytes of object</returns>
- public static byte[] Serialize(object obj)
- {
- using (var memoryStream = new MemoryStream())
- {
- CreateBinaryFormatter().Serialize(memoryStream, obj);
- return memoryStream.ToArray();
- }
- }
- /// <summary>
- /// Serializes an object into a stream.
- /// </summary>
- /// <param name="obj">object to be serialized</param>
- /// <param name="stream">Stream to serialize in</param>
- /// <returns>bytes of object</returns>
- public static void Serialize(object obj, Stream stream)
- {
- CreateBinaryFormatter().Serialize(stream, obj);
- }
- /// <summary>
- /// Deserializes an object from given byte array.
- /// </summary>
- /// <param name="bytes">The byte array that contains object</param>
- /// <returns>deserialized object</returns>
- public static object Deserialize(byte[] bytes)
- {
- using (var memoryStream = new MemoryStream(bytes))
- {
- return CreateBinaryFormatter().Deserialize(memoryStream);
- }
- }
- /// <summary>
- /// Deserializes an object from given stream.
- /// </summary>
- /// <param name="stream">The stream that contains object</param>
- /// <returns>deserialized object</returns>
- public static object Deserialize(Stream stream)
- {
- return CreateBinaryFormatter().Deserialize(stream);
- }
- /// <summary>
- /// Deserializes an object from given byte array.
- /// Difference from <see cref="Deserialize(byte[])"/> is that; this method can also deserialize
- /// types that are defined in dynamically loaded assemblies (like PlugIns).
- /// </summary>
- /// <param name="bytes">The byte array that contains object</param>
- /// <returns>deserialized object</returns>
- public static object DeserializeExtended(byte[] bytes)
- {
- using (var memoryStream = new MemoryStream(bytes))
- {
- return CreateBinaryFormatter(true).Deserialize(memoryStream);
- }
- }
- /// <summary>
- /// Deserializes an object from given stream.
- /// Difference from <see cref="Deserialize(Stream)"/> is that; this method can also deserialize
- /// types that are defined in dynamically loaded assemblies (like PlugIns).
- /// </summary>
- /// <param name="stream">The stream that contains object</param>
- /// <returns>deserialized object</returns>
- public static object DeserializeExtended(Stream stream)
- {
- return CreateBinaryFormatter(true).Deserialize(stream);
- }
- private static BinaryFormatter CreateBinaryFormatter(bool extended = false)
- {
- if (extended)
- {
- return new BinaryFormatter
- {
- //TODO: AssemblyFormat = System.Runtime.Serialization.Formatters.FormatterAssemblyStyle.Simple,
- Binder = new ExtendedSerializationBinder()
- };
- }
- else
- {
- return new BinaryFormatter();
- }
- }
- /// <summary>
- /// This class is used in deserializing to allow deserializing objects that are defined
- /// in assemlies that are load in runtime (like PlugIns).
- /// </summary>
- private sealed class ExtendedSerializationBinder : SerializationBinder
- {
- public override Type BindToType(string assemblyName, string typeName)
- {
- var toAssemblyName = assemblyName.Split(',')[0];
- foreach (var assembly in AppDomain.CurrentDomain.GetAssemblies())
- {
- if (assembly.FullName.Split(',')[0] == toAssemblyName)
- {
- return assembly.GetType(typeName);
- }
- }
- return Type.GetType(string.Format("{0}, {1}", typeName, assemblyName));
- }
- }
- }
- }
|