Linq to sql 对象是否可以为会话状态序列化?

Are Linq to sql objects serializable for session state?(Linq to sql 对象是否可以为会话状态序列化?)
本文介绍了Linq to sql 对象是否可以为会话状态序列化?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

不考虑这是个好主意还是坏主意:

Without going into whether this is a good or bad idea:

当会话处于进程外时,是否可以在 ASP.NET 会话中存储 LINQ-to-SQL 域对象?

Is it possible to store a LINQ-to-SQL domain object in the ASP.NET Session, when the session is out-of-process?

我目前收到以下错误并问了这个问题,因为我怀疑 LINQ-to-SQL 对象:

I'm currently getting the following error and asked this question because I suspect the LINQ-to-SQL objects:

无法序列化会话状态.在StateServer"和SQLServer"模式下,ASP.NET 将序列化会话状态对象,因此不允许使用不可序列化的对象或 MarshalByRef 对象.如果自定义会话状态存储在自定义"模式下完成类似的序列化,则同样的限制适用.[/编辑]

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. [/EDIT]

例如

Session["Zoo"] = new Zoo() { 
                         new Lion(),
                         new Tiger(), 
                         new Elephant()
                  }

哪里:

  • Zoo、Lion、Tiger、Elephant 都来自 ZooDataContext

和 web.config 文件包含

and the web.config file contains

<sessionState
       mode="StateServer"
       stateConnectionString="tcpip=127.0.0.1:42424"
       stateNetworkTimeout="10"
       sqlConnectionString="SqlStateConnectionString"
       sqlCommandTimeout="30"
       timeout="20"
       regenerateExpiredSessionId="true"/>

推荐答案

在存储在会话或其他任何可能想要序列化的内容之前使用 datacontractserializer 序列化它们... 最近在这里讨论:

Serialize them using the datacontractserializer before storing in session or anything else that may want to serialize... Recently discussed here:

http:///social.msdn.microsoft.com/Forums/en-US/linqtosql/thread/81c84ff4-059b-474f-9c69-b8c59027fd48

这篇关于Linq to sql 对象是否可以为会话状态序列化?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

Is Unpivot (Not Pivot) functionality available in Linq to SQL? How?(Linq to SQL 中是否提供 Unpivot(非 Pivot)功能?如何?)
How to know if a field is numeric in Linq To SQL(如何在 Linq To SQL 中知道字段是否为数字)
Linq2SQl eager load with multiple DataLoadOptions(具有多个 DataLoadOptions 的 Linq2SQl 急切加载)
Extract sql query from LINQ expressions(从 LINQ 表达式中提取 sql 查询)
LINQ Where in collection clause(LINQ Where in collection 子句)
Orderby() not ordering numbers correctly c#(Orderby() 没有正确排序数字 c#)