設置ABP默認使用中文

  • 2019 年 10 月 3 日
  • 筆記

ABP提供的啟動模板, 默認使用是英文:

雖然可以通過右上角的菜單切換成中文, 但是對於中國項目來說, 默認使用中文是很正常的需求.
本文介紹了如何實現默認語言的幾種方法, 希望能對ABP愛好者有所幫助, Let’s begin!

前期準備

使用ABP CLI創建一個名為AbpStudy的ASP.NET MVC項目:

abp new AbpStudy

關於MVC的啟動模板可以看文檔, 這裡就不贅述.

使用ABP版本的是當前最新的v0.19, 後續版本應該也適用

方法1: 通過服務設置

該方法參考了此回答, 謝謝@maliming.

  1. 編輯AbpStudy.Web工程下的Startup.cs文件, 在Configure方法的開始增加一行程式碼:
        public void Configure(IApplicationBuilder app, ILoggerFactory loggerFactory)          {              app.ApplicationServices.GetService<ISettingDefinitionManager>().Get(LocalizationSettingNames.DefaultLanguage).DefaultValue = "zh-Hans";     // 默認使用中文              app.InitializeApplication();          }

該方法首先獲取了SettingDefinitionManager的服務實例, 然後調用Get方法獲取了默認語言的SettingDefinition, 然後設置了默認值"zh-Hans", 即中文.

運行, 就會發現默認語言已經變成中文了:

怎麼樣, 非常簡單吧?

關於ABP的Setting, 現在官方的文檔還未寫完. 等待官方文檔完善後我會更新到文章里

方法2: 通過數據設置

雖然方法1非常簡單, 但是因為是通過程式碼寫死了默認語言, 如果想設置其他默認語言, 只能再次修改程式碼.

既然默認語言是通過Setting設置的, 那麼我們可不可以通過數據設置默認語言呢?答案是肯定的.

ABP啟動模板的資料庫中有一個名為AbpSettings的表, 裡面即是各種Setting的值.

我們可以向其中增加一條默認語言的記錄:

INSERT INTO AbpSettings(Id, Name, Value, ProviderName)  Values(newid(), 'Abp.Localization.DefaultLanguage', 'zh-Hans', 'Global')

其中的Name的值即是方法1中LocalizationSettingNames.DefaultLanguage的值, 相當於默認語言Setting的一個Key.
插入後的結果:

把方法1中我們增加的那行程式碼刪除後, 再次運行確認默認語言仍然是中文.

如果我們把記錄中的"zh-Hans"改為"en", 重新運行後默認語言就會切換成英文了.

方法3: 通過Seed設置

方法3實際上是方法2的一個改進: 我們利用了ABP提供了Seed系統(即可通過程式碼初始化系統的一些數據), 這樣我們在正式上線項目時, 不需要再額外執行SQL語句來執行數據初始化了.

首先我們把AbpSettings表中我們手動插入的那條記錄刪除.

然後在AbpStudy.Domain工程的Settings文件夾中增加一個名為AbpStudySettingDataSeedContributor的類, 用來為Setting設置初始化數據. 類程式碼如下:

    public class AbpStudySettingDataSeedContributor : IDataSeedContributor, ITransientDependency      {          private readonly IGuidGenerator _guidGenerator;          private readonly ISettingRepository _settingRepository;            public AbpStudySettingDataSeedContributor(IGuidGenerator guidGenerator, ISettingRepository settingRepository)          {              _settingRepository = settingRepository;              _guidGenerator = guidGenerator;          }            public async Task SeedAsync(DataSeedContext context)          {              await _settingRepository.InsertAsync(new Setting(                  _guidGenerator.Create(),                  LocalizationSettingNames.DefaultLanguage,                  "zh-Hans",                  GlobalSettingValueProvider.ProviderName              ));          }

該類注入GuidGenerator用來生成GUID, 和SettingRepository用來向AbpSettings表插入數據.

SeedAsync方法中使用InsertAsync方法插入了默認語言的記錄, 記錄的值與方法2中SQL中是一致的.

然後我們運行AbpStudy.DbMigrator工程, 這是啟動模板附帶的一個用來執行資料庫遷移的一個工具, 它會掃描到我們剛寫的AbpStudySettingDataSeedContributor類並調用它, 從而完成數據初始化.

AbpStudy.DbMigrator工程有自己的資料庫連接串, 定義在appsettings.json文件中, 別忘了將它修改成與Web工程中的一樣.

運行DbMigrator截圖:

再次查看AbpSettings表中的數據, 發現記錄已經插入了, 與我們使用SQL語句插入的一樣, 所以默認中文也同樣可以生效.

禁用其他語言

如果你的項目不用考慮多語言, 那麼右上角的語言切換菜單就顯得有點多餘了, 我們可以通過以下修改禁用其他語言:

修改AbpStudy.Web工程下的AbpStudyWebModule類, 將ConfigureLocalizationServices方法中其他語言的options.Languages.Add(...)程式碼刪除, 只保留中文的即可:

        private void ConfigureLocalizationServices()          {              Configure<AbpLocalizationOptions>(options =>              {                  options.Resources                      .Get<AbpStudyResource>()                      .AddBaseTypes(                          typeof(AbpUiResource)                      );                    //options.Languages.Add(new LanguageInfo("cs", "cs", "Čeština"));                  //options.Languages.Add(new LanguageInfo("en", "en", "English"));                  //options.Languages.Add(new LanguageInfo("pt-BR", "pt-BR", "Português"));                  //options.Languages.Add(new LanguageInfo("tr", "tr", "Türkçe"));                  options.Languages.Add(new LanguageInfo("zh-Hans", "zh-Hans", "簡體中文"));              });          }

再次運行, 發現右上角語言切換的菜單就不見了, 完美!

關於ABP框架設置默認語言的方法就介紹到這, 示例工程放到GITHUB中.
Happy Coding!

Exit mobile version