注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

神殿天堂

神仙的家园

 
 
 

日志

 
 

[ASP.NET]Session在多个站点之间共享解决方案  

2013-11-05 18:43:00|  分类: asp.net |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

对于大多数的网站来说,都会使用Session来维护用户在一次会话中操作;Session对于任何Web项目来说都是必不可少的(当然除去那里网站里不包含任何用户操作的,^_^这个对于Web2.0时代的网站来说好像是不太可能的吧)。对于单独的站点来说,一个站点只用一个Session就OK了,但对于同时多个站点来说,如何对多个站点时实现Session共享呢?

  常见的作法有:

  • 使用Cookie方式实现多个站点间的共享(这种方式只限于几个站点都在同一域名的情况下);

  • 使用.net自动的状态服务(Asp.net State Service);

  • 使用.net的Session数据库;

  • 使用MemcachedDB。

  以上几种方案各有优点,至于每种方式的优点在那里,缺点在那里?一时半会真的很难说清,如果有一篇文章就能说清的,那都是扯蛋,这种东西没有在实际中使用,单单在表现上说这个方案好那个方案不好,都是扯蛋。

  我们的项目现在采用的是第三种方案,使用Session数据库解决多站点的Session共享。有不同看法的朋友都可以聊一下,下面说一下我们的实现方式:

        既然使用Session数据库了,当然必须要先对数据库进行创建,既然是使用微软的方案了,微软肯定也就为大家提供了相应的实现方式。通过命令行方式进入:

    1 C:\Windows\Microsoft.NET\Framework64\v4.0.30319

    在此目录下运行:

    1 aspnet_regsql.exe -sstype c -ssadd -d 你的数据库名 -U 用户名 -P 密码 -S 数据库服务地址

    注意:此处的参数是区分大小写的;执行完上述命令后,会进行Session数据库创建阶段,创建完成后可以打开数据库查看创建是否成功。

    Session数据库创建成功了并不代表就可以实现多项目的Session共享了,还需要对目前的Session数据库做一些小小的手脚,其实就是为了欺骗数据库说“哎,我就一个应用程序在运行。^_^”。下面来看看怎么做这点小手段:

ALTER PROCEDURE [dbo].[TempGetAppID]  

@appName    tAppName,  

@appId int OUTPUT  

AS  

SET @appName=LOWER(@appName)  

SET @appId=NULL  

  

SELECT top 1 @appId= AppId  

FROM [SNSSessionDB].dbo.ASPStateTempApplications 

--WHERE AppName = @appName

 

IF @appId IS NULL 

BEGIN 

BEGIN TRAN 


SELECT @appId= AppId 

FROM [SNSSessionDB].dbo.ASPStateTempApplications WITH (TABLOCKX) 

WHERE AppName =@appName 

 

IF @appId IS NULL 

BEGIN 

EXEC GetHashCode @appName, @appId OUTPUT 

 

INSERT [SNSSessionDB].dbo.ASPStateTempApplications 

VALUES 

         (@appId, @appName) 

IF @@ERROR=2627

BEGIN 

DECLARE @dupApp tAppName 

 

SELECT @dupApp=RTRIM(AppName) 

FROM [SNSSessionDB].dbo.ASPStateTempApplications  

WHERE AppId =@appId 

 

RAISERROR('SQL session state fatal error: hash-code collision between applications ''%s'' and ''%s''. Please rename the 1st application to resolve the problem.',  

18, 1, @appName, @dupApp) 

END 

END 

 

COMMIT 

END 

RETURN 0

    其实只是做了一点改动,就是加了一个top 1 ,我每次查的时候,只能第一次的AppID这样的话,就是说我多个项目只一个Session实例。

    上面的各种手段都做了,其实目的只有一个就是在项目中使用这个Session数据库(发点牢骚:说微软坑爹吧,其实一点都不假,他啥都替你想到了,我们这只简单的会使用他就行了,这也是一代一代.NET开发人员的悲剧,每次微软发生新的技术改动,我们这些苦逼的开发人员就要去学习学习,然后微软突然那天说我不对这个技术再做升级了,我要放弃他了,好了你就看吧,大街上一个个苦着脸的,有一半都是搞开发的。)。怎么在项目中使用他呢?修改 web.config   在system.web 加入或修改以下项

1 <httpCookies domain="news.com" /> 

2 <sessionState mode="SQLServer" sqlConnectionString="data source=[Server];initial catalog=[DataBase];user id=[UserName];password=[Password]" allowCustomSqlDatabase="true"  timeout="120"/> 

  4. OK,你大功告成了.记得重启一下IIS ,最好把自己本机上的cookie或垃圾项清除一下,这样效果更好。

  通过上面的一系列操作,终于OK了,在项目中使用的时候,就像我们平常一样赋值和调用就OK了。

  OK了,终于写完了。


  评论这张
 
阅读(4)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018