異なるアプリ間でセッションを共有したい場合、いくつかのことを行う必要があります。
まず、セッション状態を SQL モードで実行する必要があります。この時点で、SQL セッション状態がマシン キーと _appDomainAppId を使用して、アプリが独自のセッション データにアクセスするためのキーを生成することがわかりました。そのため、すべてのアプリでこれらを同じに保つ必要があります。
アプリの Web 構成では、同じマシン キーを使用する必要があります。これは、system.web タグ EG 内の任意の場所にすることができます。
<machineKey decryptionKey="EDCDA6DF458176504BBCC720A4E29348E252E652591179E2" validationKey="CC482ED6B5D3569819B3C8F07AC3FA855B2FED7F0130F55D8405597C796457A2F5162D35C69B61F257DB5EFE6BC4F6CEBDD23A4118C4519F55185CB5EB3DFE61"/>
appSetting "ApplicationName" を追加し、名前を付けます (これは両方のアプリで同じである必要があります)。次に、_appDomainAppId を変更する共有セッション モジュールを作成する必要があります。以下は私が使用しているものです。
namespace YourApp
{
using System.Configuration;
using System.Reflection;
using System.Web;
/// <summary>class used for sharing the session between app domains</summary>
public class SharedSessionModule : IHttpModule
{
#region IHttpModule Members
/// <summary>
/// Initializes a module and prepares it to handle requests.
/// </summary>
/// <param name="context">An <see cref="T:System.Web.HttpApplication"/>
/// that provides access to the methods,
/// properties, and events common to all application objects within an ASP.NET
/// application</param>
/// <created date="5/31/2008" by="Peter Femiani"/>
public void Init(HttpApplication context)
{
// Get the app name from config file...
string appName = ConfigurationManager.AppSettings["ApplicationName"];
if (!string.IsNullOrEmpty(appName))
{
FieldInfo runtimeInfo = typeof(HttpRuntime).GetField("_theRuntime", BindingFlags.Static | BindingFlags.NonPublic);
HttpRuntime theRuntime = (HttpRuntime)runtimeInfo.GetValue(null);
FieldInfo appNameInfo = typeof(HttpRuntime).GetField("_appDomainAppId", BindingFlags.Instance | BindingFlags.NonPublic);
appNameInfo.SetValue(theRuntime, appName);
}
}
/// <summary>
/// Disposes of the resources (other than memory) used by the module that
/// implements <see cref="T:System.Web.IHttpModule"/>.
/// </summary>
/// <created date="5/31/2008" by="Peter Femiani"/>
public void Dispose()
{
}
#endregion
}
}
Web 構成では、このモジュールを追加する必要があります。
<add name="SharedSessionModule" type="YourApp.SharedSessionModule, YourApp, Version=1.0.0.0, Culture=neutral" />
最後に行うことは、セッション Cookie がドメイン間を通過できるようにすることです...
var session = HttpContext.Current.Session;
var request = HttpContext.Current.Request;
var cookie = request.Cookies["ASP.NET_SessionId"];
if (cookie != null && session != null && session.SessionID != null)
{
cookie.Value = session.SessionID;
cookie.Domain = "yourappdomain.com";
// the full stop prefix denotes all sub domains
cookie.Path = "/"; // default session cookie path root
}
そして、それはうまくいくはずです。