ASP.NET默认的InProc模式的Session既浪费内存又在网站重启时存在数据丢失问题,SQLServer模式的Session只支持SQL Server又需要命令行配置。使用EntityFramwork实现Custom既可以利用EntityFramework实现自定义的SessionProvider既可以避免数据丢失又不用捆绑到Sql Server上,还可以采用CodeFirst的自动生成数据库的方式,让我们不再需要命令行配置。
我们可以按照实际情况,对低配置单个网站采用嵌入式数据库,对负载均衡的Session统一使用分布式的Session服务器避免状态丢失,更可以在后期不用修改原有代码,只通过修改web.config方便的添加和切换其他提供了EntityFramework的数据库。
1.定义实体:
实体的代码我通过EntityFramework的插件从数据库反向生成了ASP.NET Session的实体代码,参考github上其他的Session提供程序进行了修改,将2个表合并,依然支持不同Application级别的Session存取。
2.自定义提供程序:
主要的参考三个来源:
(1)MongoDB-ASP.NET-Session-State-Store(https://github.com/AdaTheDev/MongoDB-ASP.NET-Session-State-Store)
(2)SQLiteSessionStateStore(https://github.com/micahlmartin/SQLiteSessionStateStore)
(3)System.Web.SessionState.SqlSessionStateStore(ILSpy)
3.配置web.config
通过切换Provider的connectionStringName属性可以切换不同的数据连接。
4.测试功能:
只是简单的测试了读写。
5.查看结果:
代码已经上传到gitosc:http://git.oschina.net/myshare/EntityFramework.SessionStateStoreProvider
组件已经上传到nuget:https://www.nuget.org/packages/EfSessionStateProvider/