我做的asp.net mvc应用程序要作为一个子应用程序部署到几个站点中,需要在本应用程序中获取站点的session值。
已经使用了session state server,并设置了machine key,但还是不行。
这个问题折腾了整整一天的时间,下面是解决办法。
建立一个HttpModule
///
/// 这个模块需要放到整个管道的前端
///
public class SessionShareModule : IHttpModule
{
void IHttpModule.Init(HttpApplication context)
{
Type storeProvider = typeof(HttpSessionState).Assembly.GetType("System.Web.SessionState.OutOfProcSessionStateStore");
FieldInfo uriField = storeProvider.GetField("s_uribase", BindingFlags.Static | BindingFlags.NonPublic);
if (uriField == null)
{
throw new ArgumentException("UriField was not found");
}
uriField.SetValue(null, "xxx.cn");
context.EndRequest += new EventHandler(this.EndRequest);
}
///
/// 在请求结束之后,将所有的cookie的域都改写为 xxx.cn
///
///
///
void EndRequest(object sender, EventArgs args)
{
HttpApplication application = sender as HttpApplication;
for (int i = 0; i < application.Response.Cookies.Count; i++)
{
application.Response.Cookies[i].Domain = "xxx.cn";
}
}
void IHttpModule.Dispose()
{
}
}
模块部署
(1)将这个模块的dll文件复制到站点和子应用程序的bin目录下
(2)在站点的web.config的
子应用程序的web.config配置项可加可不加。不加的话,它会继承站点的配置项。加的话,它会覆盖站点的配置项。建议不用加。
如何让IIS下多个虚拟目录共享Session
每个虚拟目录相当于是一个应用,其中的Session是不共享的,不过你的Session存储方式设置成了 inpro,stateserver还是SQLSERVE,同样都实现不了Session共享。
但如果使用SQLSERVER数据库存储Session,则可以变相的时限共享,方法如下:
首先设置虚拟目录的Session存储在SQL上SERVER:
步骤一:创建ASPState数据库
打开CMD
进入:C:WINDOWSMicrosoft.NETFrameworkv2.0.50727
执行
aspnet_regsql.exe -S . -U sa -P 123456 -ssadd -sstype p
-s 就是服务器地址用.表示本地
-ssadd添加
-sstype p session存储在ASPState数据库中 如果是t 就存在tempdb
会话数据库创建好后。
步骤二.在虚拟目录里web.config添加一个配置节点:
在
配置节点。
弄好了,会话信息就存在在数据库中了。
打开数据库的ASPState库,查看存储过程“[TempGetAppID]” 修改它
查找这段语句:SET @appName =LOWER(@appName)
修改成SET @appName="入口虚拟目录"
修改好后,在入口虚拟目录中设置了session后,其他地方都可以共用该session了。