基於EF Core存儲的國際化服務

来源:https://www.cnblogs.com/coredx/p/18294729
-Advertisement-
Play Games

前言 .NET 官方有一個用來管理國際化資源的擴展包Microsoft.Extensions.Localization,ASP.NET Core也用這個來實現國際化功能。但是這個包的翻譯數據是使用resx資源文件來管理的,這就意味著無法動態管理。雖然官方有在文檔中提供了一些第三方管理方案,但是都不太 ...


前言

.NET 官方有一個用來管理國際化資源的擴展包Microsoft.Extensions.Localization,ASP.NET Core也用這個來實現國際化功能。但是這個包的翻譯數據是使用resx資源文件來管理的,這就意味著無法動態管理。雖然官方有在文檔中提供了一些第三方管理方案,但是都不太方便。其中一個是基於Json文件的,雖然可以動態管理,但是正確的Key值有時很難猜對,特別是對於嵌套類和泛型類之類名字比較特殊的。另外兩個基於EF Core的一個只是個demo;另一個已多年未更新,且上下文生命周期和併發管理有缺陷(這個庫還是我提交pr才支持的 .NET 5)。最近項目有用到國際化功能,只好重新寫一個。

新書宣傳

有關新書的更多介紹歡迎查看《C#與.NET6 開發從入門到實踐》上市,作者親自來打廣告了!
image

相關舊文

Asp.Net Core 混合全球化與本地化支持

正文

這個擴展包代碼不多也不算複雜,主要結構參考官方內置實現。對於 .NET 5以上支持上下文工廠的版本使用上下文工廠,而對於舊版本則創建內部作用域獲取私有上下文,以此徹底避免併發問題。作用域和上下文都是需要查詢時臨時獲取和使用,查詢完數據立即銷毀避免記憶體泄漏。如果使用池化上下文工廠性能會更好。

對代碼感興趣的朋友可以移步Github。這裡直接介紹一下基本用法。

這個庫分為三個包:抽象包定義了所需介面,實體模型包定義基本實體類型,功能包定義了服務介面的實現類和用於註冊服務的擴展方法。方便為分離項目的解決方案按需引用,減少無關類型的污染。

以在ASP.NET Core中使用為例:

實體模型和上下文

public class YourLocalizationRecord : LocalizationRecord
{
    public int YourProperty { get; set; }
}

public class YourDbContext : DbContext
{
    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        // 使用預設類型。
        modelBuilder.UseLocalizationRecord();

        // 使用自定義類型,需要繼承LocalizationRecord。
        modelBuilder.UseLocalizationRecord<YourLocalizationRecord>(b =>
        {
            b.Property(r => r.ResourceCulture).HasMaxLength(32);
            b.ToTable($"{nameof(YourLocalizationRecord)}s");
        });
    }
}

服務註冊

// 對於 .NET 5 以上請使用上下文工廠。
services.AddDbContextFactoty<YourDbContext>(options => options.UseSqlite("Localization.db"));
// 或者池化工廠也是一樣的,而且更好。
services.AddPooledDbContextFactoty<YourDbContext>(options => options.UseSqlite("Localization.db"));
// 註冊一個自定義工廠服務模擬作用域上下文服務
services.AddScoped<YourDbContext>(sp => sp.GetRequiredService<IDbContextFactory<YourDbContext>>().CreateDbContext());

// 對於 .NETStandard 2.0 或 2.1 請使用上下文。
services.AddDbContext<YourDbContext>(options => options.UseSqlite("Localization.db"));

// 註冊使用預設實體類型的服務。
services.AddEntityFrameworkCoreLocalization<YourDbContext>(options =>
{
    options.ResourcesPath = "Resources";
    // 是否自動創建缺失的資源記錄
    options.CreateLocalizationResourcesIfNotExist = true;
});

//  註冊使用自定義實體類型的服務。
services.AddEntityFrameworkCoreLocalization<YourDbContext, YourLocalizationRecord>(options =>
{
    options.ResourcesPath = "Resources";
    // 是否自動創建缺失的資源記錄
    options.CreateLocalizationResourcesIfNotExist = true;
});

其他的和官方文檔用法完全一致,如果需要清除緩存使資源能在下次讀取時更新,可以使用服務IDynamicResourceStringLocalizerFactory。這個服務繼承自內置服務,獲取的IStringLocalizerFactory服務實際上也是IDynamicResourceStringLocalizerFactory的實現。

既然已經有上下文了,想怎麼讀寫數據應該不必多言了吧。實體類的屬性LocalizedContent就是翻譯後的文本。如果使用自動創建記錄,只需要查找所有這個屬性為null的記錄並翻譯保存,最後清除緩存即可。

image

結語

為了實現對 .NETStantard 2.0 的相容代碼上使用了條件編譯預處理實現一份代碼一個項目同時編譯到所有框架,最大程度共用代碼簡化代碼管理。

附上國際化官方文檔:使 ASP.NET Core 應用內容可本地化在本地化 ASP.NET Core 應用中為每個請求選擇語言/區域性

許可證:MIT
代碼倉庫:CoreDX.Extensions.Localization.EntityFrameworkCore - Github
Nuget:CoreDX.Extensions.Localization.EntityFrameworkCore
Nuget:CoreDX.Extensions.Localization.EntityFrameworkCore.Abstractions
Nuget:CoreDX.Extensions.Localization.EntityFrameworkCore.Models

QQ群

讀者交流QQ群:540719365
image

歡迎讀者和廣大朋友一起交流,如發現本書錯誤也歡迎通過博客園、QQ群等方式告知筆者。

本文地址:https://www.cnblogs.com/coredx/p/18294729.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 目錄<atomic>原子操作的概念CAS實現原理CAS操作的偽代碼:使用CAS完成變數的原子操作:CAS 操作的保證lock和鎖的概念atomic模板類構造函數公共成員函數:atomic與互斥鎖的效率比對 <atomic> C++11提供了一個原子類型std::atomic,通過這個原子類型管理的內 ...
  • 使用場景: 在python編程中,我們經常會碰到一些 需要對某路徑下所有文件進行遍歷並且逐一操作的情況, 而在遍歷時,需要判斷當前為文件夾還是文件,以進行進一步的操作。 另外, 某些情況下,路徑下可能會存在一些系統自帶的隱藏配置文件(例如Mac系統的.DS_Store文件), (它是一種 Mac 操 ...
  • 目錄<thread>this_thread命名空間1. get_id()2. sleep_for()3. sleep_until()4. yield()thread類構造函數:類方法1. get_id()2. join()3. detach()4. joinable()5. operator=6. ...
  • 本文主要介紹 HSQLDB 的基本使用,文中所使用到的軟體版本:Java 11.0.22、HSQLDB 2.7.2。 1、進程內模式 直接使用 JDBC 連接資料庫即可,如果資料庫不存在會自動創建。 1.1、file 資料庫 @Test public void inProcessFile() thr ...
  • 前言 Serilog是 .NET 上的一個原生結構化高性能日誌庫,這個庫能實現一些比內置庫更高度的定製。日誌持久化是其中一個非常重要的功能,生產環境通常很難掛接調試器或者某些bug的觸發條件很奇怪。為了在脫離調試環境的情況下儘可能保留更多線索來輔助解決生產問題,持久化的日誌就顯得很重要了。目前Ser ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他們有一個崩潰的dump讓我幫忙看下怎麼回事,確實有太多的人在網上找各種故障分析最後聯繫到了我,還好我一直都是免費分析,不收取任何費用,造福社區。 話不多說,既然有 dump 來了,那就上 windbg 說話吧。 二:WinDbg 分析 1. 為什麼 ...
  • 早兩天寫了一篇S3簡單上傳文件的小工具,知乎上看到了一個問題問如何實現顯示MINIO上傳進度,因此拓展一下這個小工具能夠在上傳大文件時顯示進度。 ...
  • 提高錄製視頻的質量,使腳本內容資料、筆記本電腦屏幕、手機錄製三者有機會整合在一起,主要解決的問題和特點:(1)在手機錄製視頻過程,不會因為眼睛看腳本內容導致眼神漂浮,眼睛與手機攝像頭保持對焦狀態。(2)隨意調整文字腳本區域大小、手機與電腦屏幕倚靠區域大小、引用資料區域大小。(3)載入錄製視頻文字腳本... ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...