2

我有www.example.com,还有store.example.com。(是的,它们是同一个父域的子域)

store.example.com在 ASP.NET 1.1 上

www.example.com在 ASP.NET 3.5 上

我想知道有哪些选项可用于在两个站点之间共享“会话”数据。我需要某种共享登录以及跟踪用户活动的能力,无论他们从哪个站点开始。

  • 显然,当从一个站点转换到另一个站点时,我可以发送一个 GUID。

  • 我也相信我可以设置一个可以跨子域共享的 cookie。我从未尝试过,但这很可能是我会做的。我还不清楚这是一个真正的“会话”cookie,还是我只是设置了一个低到期日期?

这些是我最好的选择还是有别的选择?

4

3 回答 3

6

如果您想在不同的应用程序之间共享会话,您需要做一些事情。

首先,您需要在 SQL 模式下运行会话状态。在这一点上,我发现 SQL 会话状态使用机器密钥和您的 _appDomainAppId 为您的应用程序生成一个密钥以访问它自己的会话数据。因此,我们需要在您的所有应用程序之间保持这些相同。

在您的应用程序的网络配置中,您需要使用相同的机器密钥。这可以是 system.web 标签内的任何位置,例如:

    <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
  }
}

在网络配置中,您需要添加此模块:

      <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
  }

这应该可以解决问题。

于 2009-08-13T11:41:06.003 回答
3

重要的是要正确设置 cookie 域。

如果域设置为.example.com(注意前导句点),那么它应该包含在对 example.com 以及所有子域的请求中。

我假设您有一种在不同子域之间共享数据的方法。

于 2008-10-29T07:10:45.367 回答
-3

以下是您在 PHP 中的操作方式:

http://php.dtbaker.com.au/post/keeping_cookies_across_multiple_sub_domains.html

于 2008-10-29T06:34:14.427 回答