配置与扩展


配置文件

  通过文件可以配置多个本地化管理器,通过更换 default 的值即可实现无缝切换。配置文件如下:

  • .Net Framework 下的 app.config 或 web.config 文件
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <sectionGroup name="fireasy">
      <section name="stringLocalizers" type="Fireasy.Common.Localization.Configuration.StringLocalizerConfigurationSectionHandler, Fireasy.Common" />
    </sectionGroup>
  </configSections>
  <fireasy>
    <stringLocalizers default="xml">
      <localizer name="xml" type="Fireasy.Common.Localization.XmlStringLocalizerManager, Fireasy.Common" />
      <localizer name="demo" type="demo.StringLocalizerManager, demo" />
    </stringLocalizers>
  </fireasy>
</configuration>
  • .Net Core 下的 appsettings.json 文件
{
  "fireasy": {
    "stringLocalizers": {
      "default": "xml",
      "settings": {
        "xml": {
          "type": "Fireasy.Common.Localization.XmlStringLocalizerManager, Fireasy.Common"
        },
        "demo": {
          "type": "demo.StringLocalizerManager, demo"
        }
      }
    }
  }
}

  StringLocalizerFactory 工厂类可以根据配置创建一个 IStringLocalizerManager 实例。如下所示:

[TestMethod]
public void TestCreateManager()
{
    var manager1 = StringLocalizerFactory.CreateManager();
    Assert.IsNotNull(manager1); // xml

    var manager2 = StringLocalizerFactory.CreateManager("demo");
    Assert.IsNotNull(manager2); // demo
}

  在使用 IOC 的环境中,通过构造注入或属性注入得到的 IStringLocalizerManager 的实例对应的是指向 default 的配置项。