是LINQ到SQL对象序列化的会话状态?(Are Linq to sql objects seria

2019-09-02 05:52发布

如果没有进入这是否是好还是坏主意:

是否有可能存储在ASP.NET会话一个LINQ到SQL域对象,在会话外的过程吗?

[编辑]我目前收到以下错误,问这个问题,因为我怀疑LINQ到SQL对象:

无法序列化会话状态。 在“的StateServer”和“SQLServer的”模式,ASP.NET将序列化会话状态的对象,并且作为结果的非序列化的对象或对象MarshalByRef不允许。 如果类似的序列化是通过在“自定义”模式自定义会话状态存储做了同样的限制。 [/编辑]

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

哪里:

  • 动物园,狮子,老虎,大象都来一个ZooDataContext出来

和web.config文件中包含

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

Answer 1:

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

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



Answer 2:

要使用二进制格式(如SessionState的使用,我相信),你需要生成你自己从DBML代码(我这样做,目前与LINQ2SQL T4模板)。

以下需要被标记为[NonSerialized]

  • EntityRef
  • EntitySet
  • 所有事件(你需要条条框框要做到这一点,练习阅读器)

另外,构造逻辑需要被移动到OnCreated 。 你还必须确保OnCreated反序列化时,这样的对象可以再次成为有用之称。 在与done [OnDeserializing]属性。



Answer 3:

我相信你会需要标记你的对象为可序列化。 我不知道是否有办法为所有生成的对象做到这一点,但对于那些你投入的会话,你可以创建一个部分类(如狮子),并给它Serializable属性。



文章来源: Are Linq to sql objects serializable for session state?