EPiServer.Configuration.Settings.Instance - 应用程序使用 siteId=“x”的设置进行初始化,但当前请求映射到 siteId=“y”
我们有一个 EPiServer 5.x 企业项目,其中在 EPiServer.config 中声明了多个站点,
这些站点在 IIS 中设置为单独的网站,指向相同的 Webroot,将每个 IIS 站点的主机条目与 EPiServer.config 中为每个站点声明的 siteHosts 相匹配
<site description="Site 1" siteId="SiteOne">
<siteHosts>
<add name="www.siteone.se" language="sv" />
<add name="*"/>
</siteHosts>
<siteSettings .../>
</site>
<site description="Site 2" siteId="SiteTwo">
<siteHosts>
<add name="www.sitetwo.fi" language="fi" />
</siteHosts>
<siteSettings .../>
</site>
我们遇到的一个问题是,每当我们重新启动 IIS 中的一个或多个站点并在浏览器中导航到该站点时,它(看似随机)会抛出错误并记录:
应用程序初始化为 siteId="SiteOne" 的设置,但当前 请求映射到 siteId="SiteTwo"
我可以看到,如果当前请求主机与 EPiServer.config 中的任何 siteHost 条目不匹配,它将默认为带有以下内容的 siteHost 站点通配符“*”代替。
At least one <site> section must omit the <siteHosts> section, or <add name=\"*\"> to the <siteHosts> section.
问题:为什么会发生这种情况? IIS 中的站点配置为侦听单独的 IP 并绑定到特定主机。
问题:由于 EPiServer.Configuration.Settings.Instance 有一个公共设置器,因此稍后能够手动设置它是一个好主意吗? (通过一些 .aspx 或诸如此类的东西,而不是重新启动应用程序)
当然,最好对此进行永久修复,而不是拼凑一些半成品的 .aspx 修复程序。
从类“EPiServer.Configuration.Settings”:
public static Settings Instance
{
get
{
if (HttpContext.Current == null)
{
if (_instance == null)
{
throw new ApplicationException("First time you call Settings.Instance you must have a valid HttpContext.");
}
return _instance;
}
Settings settings = MapUrlToSettings(HttpContext.Current.Request.Url);
if (_instance == null)
{
_instance = settings;
}
else if (_instance != settings)
{
throw new ConfigurationErrorsException(string.Format("Application is initialized with settings for siteId=\"{0}\", but current request maps to siteId=\"{1}\"", _instance.Parent.SiteId, settings.Parent.SiteId));
}
return _instance;
}
set
{
_instance = value;
}
}
public static Settings MapUrlToSettings(Uri url)
{
Settings settings;
if (url == null)
{
throw new ArgumentNullException("url", "An initialized Uri instance is required.");
}
if (!url.IsAbsoluteUri)
{
throw new ArgumentException("The Uri must be absolute to use for mapping.", "url");
}
if (!string.IsNullOrEmpty(url.DnsSafeHost))
{
settings = MapHostToSettings(url.DnsSafeHost, true);
}
else
{
settings = MapHostToSettings("*", true);
}
string absolutePath = url.AbsolutePath;
string str2 = settings.SiteUrl.AbsolutePath;
if (!absolutePath.StartsWith(str2, StringComparison.OrdinalIgnoreCase) && !string.Equals(absolutePath + "/", str2, StringComparison.OrdinalIgnoreCase))
{
throw new ConfigurationErrorsException(string.Format("The URL \"{0}\" maps to siteId=\"{1}\" but has a path that is outside the application root (application root is \"{2}\").", url.ToString(), settings.Parent.SiteId, settings.SiteUrl.AbsolutePath));
}
return settings;
}
public static Settings MapHostToSettings(string hostName, bool fallback)
{
Settings settings;
if (_hostToSettings == null)
{
InitializeAllSettings();
}
if (_hostToSettings.TryGetValue(hostName, out settings))
{
return settings;
}
if (!fallback)
{
return null;
}
return _hostToSettings["*"];
}
We have a EPiServer 5.x enterprise project with several sites declared in EPiServer.config
These are set up as separate websites in IIS pointing at the same webroot matching the host entry for each IIS site to the siteHosts declared for each site in EPiServer.config
<site description="Site 1" siteId="SiteOne">
<siteHosts>
<add name="www.siteone.se" language="sv" />
<add name="*"/>
</siteHosts>
<siteSettings .../>
</site>
<site description="Site 2" siteId="SiteTwo">
<siteHosts>
<add name="www.sitetwo.fi" language="fi" />
</siteHosts>
<siteSettings .../>
</site>
A problem we have been experiencing is that whenever we restart one or more of the sites in IIS and navigate to that site in a browser it (seemingly randomly) throws an error and logs:
Application is initialized with
settings for siteId="SiteOne", but current
request maps to siteId="SiteTwo"
if looking into the class "EPiServer.Configuration.Settings" below I can see that if the current request host does not match any of siteHost entry in EPiServer.config it will default to the siteHost site with the wildcard "*" instead.
At least one <site> section must omit the <siteHosts> section, or <add name=\"*\"> to the <siteHosts> section.
Question: Why would this happen? The sites in IIS are configured to listen to separate IP's and are bound to specific hosts.
Question: Since the EPiServer.Configuration.Settings.Instance has a public setter, would it be a good idea to be able to set this manually later? (via some .aspx or whatnot instead of restarting the application)
Of course it would be better to get a permanent fix to this instead of hacking together some half baked .aspx fix.
From the class "EPiServer.Configuration.Settings" :
public static Settings Instance
{
get
{
if (HttpContext.Current == null)
{
if (_instance == null)
{
throw new ApplicationException("First time you call Settings.Instance you must have a valid HttpContext.");
}
return _instance;
}
Settings settings = MapUrlToSettings(HttpContext.Current.Request.Url);
if (_instance == null)
{
_instance = settings;
}
else if (_instance != settings)
{
throw new ConfigurationErrorsException(string.Format("Application is initialized with settings for siteId=\"{0}\", but current request maps to siteId=\"{1}\"", _instance.Parent.SiteId, settings.Parent.SiteId));
}
return _instance;
}
set
{
_instance = value;
}
}
public static Settings MapUrlToSettings(Uri url)
{
Settings settings;
if (url == null)
{
throw new ArgumentNullException("url", "An initialized Uri instance is required.");
}
if (!url.IsAbsoluteUri)
{
throw new ArgumentException("The Uri must be absolute to use for mapping.", "url");
}
if (!string.IsNullOrEmpty(url.DnsSafeHost))
{
settings = MapHostToSettings(url.DnsSafeHost, true);
}
else
{
settings = MapHostToSettings("*", true);
}
string absolutePath = url.AbsolutePath;
string str2 = settings.SiteUrl.AbsolutePath;
if (!absolutePath.StartsWith(str2, StringComparison.OrdinalIgnoreCase) && !string.Equals(absolutePath + "/", str2, StringComparison.OrdinalIgnoreCase))
{
throw new ConfigurationErrorsException(string.Format("The URL \"{0}\" maps to siteId=\"{1}\" but has a path that is outside the application root (application root is \"{2}\").", url.ToString(), settings.Parent.SiteId, settings.SiteUrl.AbsolutePath));
}
return settings;
}
public static Settings MapHostToSettings(string hostName, bool fallback)
{
Settings settings;
if (_hostToSettings == null)
{
InitializeAllSettings();
}
if (_hostToSettings.TryGetValue(hostName, out settings))
{
return settings;
}
if (!fallback)
{
return null;
}
return _hostToSettings["*"];
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
在 EPiServer 6 及更高版本中,有一个令人恼火的 EPiServerFramework.config,其中有一个名为的节点。第一次访问 Episerver 站点时,它会添加一个将 IIS 站点 ID 与 EPiServer 站点 ID 相匹配的键值。
出现“应用程序已使用 siteId 的设置初始化...”错误的最常见原因是您重新安装了计算机(或在 IIS 中进行了小更改...),然后在不同的环境中设置了站点。命令。例如,站点 X 第一次具有 Id 1,但随后获得 Id 2。如果您的站点 Y 曾经具有 Id 2,并且您已将其映射到 EPiServerFramework.config 中,那么它将引发异常。
摆脱这个问题的最快方法是
In EPiServer 6 and above, there is this irritating EPiServerFramework.config, which have a node called <automaticSiteMapping>. The first time you access a episerver site, it adds a key value that matches IIS site Id with the EPiServer site Id.
The most common cause for getting the "Application is initialized with settings for siteId..." error is that you for example have reinstalled your computer (or made a small change in the IIS...) and then setup your sites in a different order. For example site X has Id 1 the first time, but then gets Id 2. If you have site Y that used to have Id 2 and you have that mapped in your EPiServerFramework.config, then it will throw an exception.
The fastes way to get rid of this is
我以前遇到过同样的错误。就我而言,我们为 IIS 中的站点配置了多个主机标头,根据 episerver.config 中的 sitehosts 定义,其中一个主机标头是错误的。
如果您使用多个主机标头,请根据 episerver.config 文件仔细检查它们,以确保它们配置在相同的“站点”上
I've encountered the same error before. I my case, we had multiple host headers configured for the sites in IIS, and one of these host headers was wrong according to the sitehosts definition in episerver.config.
If you use multiple host headers, double check them against the episerver.config files to assure they are configured on the same "sites"