2013-09-21 5 views
3

Я получаю следующее сообщение об ошибке, и интересно, если мы можем сделать System.Data.Linq.EntitySet сериализуемымНевозможно сериализации состояния сеанса с помощью StateServer

Unable to serialize the session state. In 'StateServer' and 'SQLServer' mode, ASP.NET will serialize the session state objects, and as a result non-serializable objects or MarshalByRef objects are not permitted. The same restriction applies if similar serialization is done by the custom session state store in 'Custom' mode.

Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code.

Exception Details: System.Web.HttpException: Unable to serialize the session state. In 'StateServer' and 'SQLServer' mode, ASP.NET will serialize the session state objects, and as a result non-serializable objects or MarshalByRef objects are not permitted. The same restriction applies if similar serialization is done by the custom session state store in 'Custom' mode.

Source Error:

An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below.

Stack Trace:

[SerializationException: Type 'System.Data.Linq.EntitySet`1[[NES.HiLo.Data.DAO.UserResource, NES.HiLo.Data, Version=1.0.5012.39381, Culture=neutral, PublicKeyToken=null]]' in Assembly 'System.Data.Linq, Version=3.5.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089' is not marked as serializable.] System.Runtime.Serialization.FormatterServices.InternalGetSerializableMembers(RuntimeType type) +7738715 System.Runtime.Serialization.FormatterServices.GetSerializableMembers(Type type, StreamingContext context) +258 System.Runtime.Serialization.Formatters.Binary.WriteObjectInfo.InitMemberInfo() +111 System.Runtime.Serialization.Formatters.Binary.WriteObjectInfo.InitSerialize(Object obj, ISurrogateSelector surrogateSelector, StreamingContext context, SerObjectInfoInit serObjectInfoInit, IFormatterConverter converter, ObjectWriter objectWriter) +422 System.Runtime.Serialization.Formatters.Binary.WriteObjectInfo.Serialize(Object obj, ISurrogateSelector surrogateSelector, StreamingContext context, SerObjectInfoInit serObjectInfoInit, IFormatterConverter converter, ObjectWriter objectWriter) +51 System.Runtime.Serialization.Formatters.Binary.ObjectWriter.Write(WriteObjectInfo objectInfo, NameInfo memberNameInfo, NameInfo typeNameInfo) +7636088 System.Runtime.Serialization.Formatters.Binary.ObjectWriter.Serialize(Object graph, Header[] inHeaders, __BinaryWriter serWriter, Boolean fCheck) +461 System.Runtime.Serialization.Formatters.Binary.BinaryFormatter.Serialize(Stream serializationStream, Object graph, Header[] headers, Boolean fCheck) +134 System.Web.Util.AltSerialization.WriteValueToStream(Object value, BinaryWriter writer) +1577

ответ

6

Исключение фактически говорит вам, уже то, что вопрос, EntitySet является не сериализуется. Поэтому он не может быть сохранен в состоянии сеанса, если вы используете функцию Session DB.

EntitySet не реализует/не поддерживает это. Поэтому, чтобы сохранить его в состоянии сеанса, вам нужно будет прочитать данные в свои собственные объекты, а затем сохранить их, например. Или просто не пытайтесь использовать состояние сеанса для «сохранения» этих объектов, потому что обычно вы не хотите этого делать (нет лучшей практики).

+0

Это должно быть отмечено как ответ – dyslexicanaboko

+0

Итак, что лучше всего подходит для такого рода вещей? – Coops

+0

Реализовать свое приложение как безгосударственное, так как вы можете предотвратить множество проблем. Всякий раз, когда вам нужны пользовательские состояния или данные профиля, вы можете сохранить это в базе данных (выделенные таблицы) и загрузить данные в память. При необходимости вы можете использовать кэши распределенной памяти для хранения данных для нескольких веб-серверов. – MichaC

2

Одним из лучших решений является использование библиотеки Json.NET.

Эта библиотека позволяет выполнять двунаправленное преобразование объектов LINQ в их представление JSON. Например, вы можете хранить продукт в состоянии отображения, с помощью всего нескольких строк кода:

Product product = new Product(); 
product.Name = "Apple"; 
product.Expiry = new DateTime(2008, 12, 28); 
product.Price = 3.99M; 
string json = JsonConvert.SerializeObject(product); 
ViewState["product"] = json ; 

и получить его обратно тоже:

product = JsonConvert.DeserializeObject<Product>(ViewState["product"] as string); 

См эти 2 ссылки больше:

1.) http://james.newtonking.com/projects/json-net.aspx

2.) http://www.codeplex.com/json/

Если ваше приложение использует управление in-process, вы сможете хранить объекты LINQ в сеансе, приложении и кеше. Однако вы не сможете сохранить их в состоянии просмотра.

Причина в том, что данные, хранящиеся в состоянии представления, сериализуются с использованием бинарного форматирования.

Поэтому еще одно решение, чтобы сделать LINQ класс сериализации, вам необходимо пометить все System.Data.Linq.EntitySet и System.Data.Linq.EntityRef поля с атрибутом NonSerialized и помечать Serializable приписывают LINQ класс.

И еще одно решение - вручную извлечь данные из объектов LINQ, сохранить их в каком-то промежуточном формате (class, struct, ... и т. Д.), А затем вручную перевести его обратно.

Смежные вопросы