Orchard Core 配置项说明
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 配置项说明的更多相关文章
- Orchard Core一分钟搭建ASP.NET Core CMS
Orchard Core 是Orchard CMS的ASP.NET Core版本. Orchard Core是全新一代的ASP.NET Core CMS. 官方文档介绍:http://orchardc ...
- Orchard Core Framework:ASP.NET Core 模块化,多租户框架
Orchard Core Framework:ASP.NET Core 模块化,多租户框架 上一篇编写Orchard Core一分钟搭建ASP.NET Core CMS ,介绍ASP.NET Core ...
- 发布基于Orchard Core的友浩达科技官网
2018.9.25 日深圳市友浩达科技有限公司发布基于Orchard Core开发的官网 http://www.weyhd.com/. 本篇文章为你介绍如何基于Orchard Core开发一个公司网站 ...
- Orchard Core学习一
Orchard Core学习一 Orchard Core是ASP.NET Core上Orchard CMS的重新开发. Orchard Core由两个不同的目标组成: Orchard核心框架:用于在A ...
- Orchard Core 增加了一个API模块,要怎么调用
如下,我在Orchard Core框架中添加了一个API的模块,并且定义了对应的权限才可以调用,那么我们现在考虑的就是要怎么去调用它. 首先,我们用Fiddler查看下我们正常的登录的http报文,直 ...
- Orchard Core 自定义权限配置
在我们为Orchard Core配置了一个新的Module之后,我们要考虑的是谁可以访问这个Module,那么这里就涉及到了一个权限的配置.如下图,添加了自定义的权限: Orchard Core源码: ...
- Orchard Core 模块化
在上一篇文章谈到如何搭好一个基础的Orchard Core项目. 今天要尝试Orchard Core的模块化. 我自己的理解:一个系统可以分成一个个模块,这一个个模块是由一个个类库去实现的. 首先,在 ...
- 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. ...
- 初试Orchard Core CMS
关于Orchard Core CMS,这是一套内容管理系统(Content Management System),看一下来自官方文档的解释,什么是Orchard CMS. Orchard is a f ...
随机推荐
- springboot配置ssl-pfx
application.yml server: port: 9443 ssl: key-store: classpath:4148017_qra.meeno.net.pfx key-store-typ ...
- Socket编程 Tcp和粘包
大多数程序员都要接触网络编程,Web开发天天和http打交道.稍微底层一点的程序员,就是TCP/UDP . 对程序员来说,Tcp/udp的核心是Socket编程. 我的浅薄的观点---------理解 ...
- Unable to instantiate org.apache.hadoop.hive.ql.metadata.SessionHiveMetaStoreClient
1.今天在进行hive测试的时候,发现hive一直进不去,并且报了这个错误. Unable to instantiate org.apache.hadoop.hive.ql.metadata.Sess ...
- 深入研究webpack之Tree Shaking相关属性sideEffects用处
Tree Shaking我原来也只是了解,这次碰巧深入研究了下,就写个博客记录一下,网上有很多讲Tree Shaking的,我写的这篇跟他们侧重点不一样 Tree Shaking相关的基础知识 1 w ...
- git《一》
org.eclipse.jgit.api.errors.TransportException: https://gitee.com/wbweb/springboot_vue.git: Authenti ...
- 小程序es6
在小程序中使用ES6的新特性ECMAScript 6(简称ES6)是于2015年6月正式发布的JavaScript语言的标准,正式名为ECMAScript 2015(ES2015). 小程序在很久之前 ...
- ROS catkin_make error Could not find a package configuration file provided by "actionlib_msgs"
在使用ROS catkin_make编译的时候,出现类似如下错误 CMake Error at /opt/ros/kinetic/share/catkin/cmake/catkinConfig.cma ...
- Android常见面试题(一)
ANDROID(一) Activity 1.什么是Activity? 请描述一下生命周期 Activity: 一个Activity是一个应用程序组件,提供一个屏幕,用户可以用来交互为了完成某项任务,例 ...
- python 逆序按行读取文件
How to read a file in reverse order? import os def readlines_reverse(filename): with open(filename) ...
- 通过cglab 实现 Spring AOP
1新建一个目标类 public class StudentService { public void delete(){ System.out.println("删除学生"); } ...