Orchard Core使用IShellConfiguration扩展了ASP.NET Core IConfiguration,以允许在应用程序范围的配置之上进行特定于租户的配置。虽然本文档使用OrchardCore.Cms.Web.csproj示例中Web应用程序的配置,但如果您在自己的Web应用程序中使用NuGet包中的Orchard,那么在项目中也可以使用Orchard。

配置资源

Orchard Core支持配置源层次结构。

1、ASP.NET Core项目的启动项,例如OrchardCore.Cms.Web.csproj、appsettings.json或根据环境appsettings.Development.json。
2、全局租户配置App_data/appsettings.json,或根据环境App_data/appsettings.Development.json。
3、位于App_Data/Sites/{Tenant_Name}/appsettings.json文件夹中每个租户文件夹下的各个租户配置文件。注意:这些是可变文件,不支持环境版本。
4、环境变量,或通过Azure将AppSettings作为环境变量。
配置源按上述顺序加载,层次结构中较低的设置将覆盖较高配置的值,例如:全局租户值将始终被环境变量覆盖。

下面appsettings.json示例中的IShellConfiguration模式仅适用于专门支持此类配置的模块。您可以查看给定模块的代码或文档,看看情况是否如此。
OrchardCore.Cms.Web.csproj启动项目中的IShellConfiguration。
Orchard Core将所有配置数据存储在appsettings.json文件中的OrchardCore部分下:

{
"OrchardCore": {
... module configurations ...
}
}

每个Orchard Core模块在OrchardCore部分下都有自己的配置部分:

{
"OrchardCore": {
"OrchardCore.Media": {
... individual module configuration ...
}
}
}

有关更多示例,请参见appsettings.json文件。

租户的预配置说明

要在创建租户之前预先配置租户的设置值,可以指定一个以租户命名的部分,其State值为Uninitialized

{
"OrchardCore": {
"MyTenant": {
"State": "Uninitialized",
"RequestUrlPrefix": "mytenant",
"ConnectionString": "...",
"DatabaseProvider": "SqlConnection"
}
}
}

然后,预配置的租户将出现在管理员的租户列表中,这些值将在设置租户时使用。

租户建立后配置说明

要在创建租户后配置租户的值,您可以指定一个以租户命名的部分,而不必提供状态值。

{
"OrchardCore": {
"Default": {
"OrchardCore_Media": {
... specific tenant configuration ...
}
}
}
}

全局租户数据访问配置

如果您希望所有租户都访问同一数据库,该怎么办?对应的配置可以保存在一个地方,而不是逐个为所有租户设置相同的连接字符串,如下所示:

{
"OrchardCore": {
"ConnectionString": "...",
"DatabaseProvider": "SqlConnection",
"Default" : {
"State": "Uninitialized",
"TablePrefix": "Default"
}
}
}

请注意,尽管您可以对租户使用相同的配置键(如前所述),但这是在OrchardCore部分的根目录中。
为所有租户使用的数据库添加连接字符串。
DatabaseProvider应与使用的数据库引擎相对应,示例为SQL Server。
需要将TablePrefix配置为默认租户使用的前缀,以便可以为每个租户分隔表(否则,只有默认租户的表会缺少前缀)。然后,应为其他租户设置不同的前缀。
这样,通过在给定环境中配置相应数据库的设置,应用程序可以在不同环境之间轻松移动(如临时环境和生产环境)。租户的外壳设置不会包含此信息,所有租户将使用相同的全局配置。
相关主题是Shell配置提供程序。有关如何将所有外壳配置保留在数据库中的信息,请特别参阅关于数据库外壳配置提供程序的部分。

IOptions配置

您还可以从Web项目的Startup类中的代码配置IOptions。
许多Orchard Core功能都是通过管理UI配置的,站点设置存储在数据库中,和/或通过IOptions公开配置。如果您希望覆盖站点设置或默认设置,可以使用您自己的配置代码执行此操作。
例如,电子邮件模块允许通过SmtpSettings类进行SMTP配置,默认情况下,SmtpSettings类由给定租户的站点设置(在管理员上设置)填充。但是,您可以像这样覆盖Startup类中的站点设置(请注意,我们使用PostConfigure来覆盖站点设置值,但是如果模块不使用站点设置,您可以只使用Configure):

services
.AddOrchardCms()
.ConfigureServices(tenantServices =>
tenantServices.PostConfigure<SmtpSettings>(settings =>
{
settings.Port = 255;
})); // Or if you want to make use of IShellConfiguration as seen above:
services
.AddOrchardCms()
.ConfigureServices((tenantServices, serviceProvider) =>
{
// Instead of IShellConfiguration you could fetch the configuration
// values from an injected IConfiguration instance here too. While that
// would also allow you to access standard ASP.NET Core configuration
// keys it won't have support for all the hierarchical sources
// detailed above.
var shellConfiguration = serviceProvider.GetRequiredService<IShellConfiguration>();
var password = shellConfiguration.GetValue<string>("SmtpSettings:Password"); tenantServices.PostConfigure<SmtpSettings>(settings =>
{
settings.Password = password;
});
});

这将使SMTP端口使用此配置,而不考虑站点设置中定义的任何其他值。第二个示例的配置值可以来自例如appsettings.json文件,如下所示:

{
"OrchardCore": {
"SmtpSettings": {
"Password": "password"
}
}
}

在管理页面不会有此覆盖发生的提示,并且那里显示的值仍将是站点设置中配置的值,所以如果您选择这样做,您需要让您的用户知道。

ORCHARD_APP_DATA 环境变量

可以通过设置ORCHARD_APP_DATA环境变量来配置App_Data文件夹的位置。路径可以是相对于应用程序路径(./App_data)、绝对路径(/path/from/root)或完全限定路径(D:\path\to\App_data)。如果该文件夹不存在,应用程序将尝试创建它。

IShellConfiguration 配置在全局租户配置在App_data/appsettings.json中

这些设置也可以位于App_Data/appsettings.json文件夹(默认情况下不创建)中,其中指定的任何设置都将覆盖启动项目中的设置。

IShellConfiguration配置在单独的租户文件夹中

这些设置是可变的,并且在为租户设置期间写入。因此,不支持读取环境名称。此外,这些appsettings.json文件不需要OrchardCore节。

{
"OrchardCore_Media": {
... specific tenant configuration ...
}
}

IShellConfiguration通过环境变量配置

OrchardCore__OrchardCore_Media__MaxFileSize

OrchardCore__Default__OrchardCore_Media__MaxFileSize

OrchardCore__MyTenant__OrchardCore_Media__MaxFileSize

为了支持Linux,下划线_用作分隔符,例如OrchardCore_Media。 OrchardCore.Media也支持向后兼容,建议用户使用_的方式。

层级顺序

默认情况下,Orchard核心站点将在启动项目的Program.cs中使用CreateDefaultBuilder,它将按以下顺序加载IConfiguration。

1、启动项目appsettings.json。
2、启动项目appsettings.{Environment}.json。
3、用户机密(如果环境为开发)。
4、环境变量。
5、命令行参数。
6、然后,IShellConfiguration将为特定租户添加这些1.app_data/appsettings.json 2.app_data/site/{Tenant_Name}/appsettings.json。

注意:后面加载的如果具有相同Key的配置优先于较早加载的配置,以后面的为准。

Orchard Core 配置项说明的更多相关文章

  1. Orchard Core一分钟搭建ASP.NET Core CMS

    Orchard Core 是Orchard CMS的ASP.NET Core版本. Orchard Core是全新一代的ASP.NET Core CMS. 官方文档介绍:http://orchardc ...

  2. Orchard Core Framework:ASP.NET Core 模块化,多租户框架

    Orchard Core Framework:ASP.NET Core 模块化,多租户框架 上一篇编写Orchard Core一分钟搭建ASP.NET Core CMS ,介绍ASP.NET Core ...

  3. 发布基于Orchard Core的友浩达科技官网

    2018.9.25 日深圳市友浩达科技有限公司发布基于Orchard Core开发的官网 http://www.weyhd.com/. 本篇文章为你介绍如何基于Orchard Core开发一个公司网站 ...

  4. Orchard Core学习一

    Orchard Core学习一 Orchard Core是ASP.NET Core上Orchard CMS的重新开发. Orchard Core由两个不同的目标组成: Orchard核心框架:用于在A ...

  5. Orchard Core 增加了一个API模块,要怎么调用

    如下,我在Orchard Core框架中添加了一个API的模块,并且定义了对应的权限才可以调用,那么我们现在考虑的就是要怎么去调用它. 首先,我们用Fiddler查看下我们正常的登录的http报文,直 ...

  6. Orchard Core 自定义权限配置

    在我们为Orchard Core配置了一个新的Module之后,我们要考虑的是谁可以访问这个Module,那么这里就涉及到了一个权限的配置.如下图,添加了自定义的权限: Orchard Core源码: ...

  7. Orchard Core 模块化

    在上一篇文章谈到如何搭好一个基础的Orchard Core项目. 今天要尝试Orchard Core的模块化. 我自己的理解:一个系统可以分成一个个模块,这一个个模块是由一个个类库去实现的. 首先,在 ...

  8. Orchard Core 版本冲突 The type 'FormTagHelper' exists in both 'Microsoft.AspNetCore.Mvc.TagHelpers, Version=2.1.1.0, Culture=neutral, PublicKeyToken=adb9793829ddae60' and...

    最近老大让我看Orchard Core,这是一个CMS系统.可以先参考大佬的文章:https://www.cnblogs.com/shanyou/archive/2018/09/25/9700422. ...

  9. 初试Orchard Core CMS

    关于Orchard Core CMS,这是一套内容管理系统(Content Management System),看一下来自官方文档的解释,什么是Orchard CMS. Orchard is a f ...

随机推荐

  1. Flink Streaming状态处理(Working with State)

    参考来源: https://www.jianshu.com/p/6ed0ef5e2b74 https://blog.csdn.net/Fenggms/article/details/102855159 ...

  2. IPython中也要保持优雅(DRY原则)

    What is IPython? IPython provides a rich architecture for interactive computing with: A powerful int ...

  3. 新东方APP技术架构演进, 分布式系统架构经验分享

    今天的演讲题目是"新东方APP技术架构演进, C端技术经验分享" 作者:张建鑫, 曾任IBM高级软件架构师, 滴滴高级技术专家, 现任新东方集团高级技术总监 古代东西方的思想家都产 ...

  4. php 字符串分割输出

    分割字符串 //利用 explode 函数分割字符串到数组 复制代码代码如下:<?php $source = "hello1,hello2,hello3,hello4,hello5&q ...

  5. blender Text on Curve Text on Sphere

    Text on Curve Shift + A 添加一个 BezierCurve Shift + A 添加一个 Text,Tab 编辑,再次 Tab 退回 Object Mode 选中 Text,Ad ...

  6. SpringBoot2.x+mybatis plus3.x集成Activit7版本

    最近在写一个开源项目ruoyi-vue-pro,暂时负责Activiti7工作流的搭建,接这个任务一个原因,是比较好奇Activiti7版本与先前的5.6版本究竟有什么区别,因为先前在工作当中,最开始 ...

  7. 快速构建CLI程序并发布到PyPi

    构造一个简单的CLI程序 typer 这个从去年就被各种营销号吹成Web框架的 第三方库, 与 FastAPI 同出一人之手,它不是Web框架,它是一个用来构建CLI程序的库,我们就简单搞个例子 # ...

  8. NOIP模拟22「d·e·f」

    T1:d   枚举.   现在都不敢随便打枚举了.   实际上我们只关注最后留下的矩阵中最小的长与宽即可.   所以我们将所有矩阵按a的降序排列.   从第\(n-m\)个开始枚举.   因为你最多拿 ...

  9. PyRevit开发第一步:获取Revit文档Document

    1.安装PythonShell插件 PythonShell 2018 插件下载 交流QQ群: 17075104 新建项目后,运行功能Python Shell, 在弹出的窗口中复制或输入以下引用代码模块 ...

  10. Mybatis-基本学习(上)

    目录 Mybatis mybatis开始 -----环境准备 一.简介 1.什么是MyBatis 2.持久化 3.持久层 4.为什么需要Mybatis? 二.第一个Mybatis程序 1.搭建环境 1 ...