跳到主要內容

Asp.Net Core Web 多國語系(一)

微軟內建的多國語系目前分為三種 :

第一種是寫在Controller中的(通常用在商業邏輯判斷之錯誤顯示)

第二種是寫在View中的(通常用於畫面功能顯示以及UI顯示用)

第三種是寫在Data Model的Attribute中, 然後自動顯示在View中(通常用於與資料庫相關之資訊顯示, 如欄位名稱, 資料輸入之格式錯誤訊息)

我先來嘗試寫第一種 - Controller :

首先我先建立一個 Asp.Net Core 的 MVC 專案 NetCore (程式碼下載, 如果想從無到有自己動手一步一步做, 可以參考微軟官網範例MvcMovie, 我的專案就是從這小改來的, 只是將資料庫從LocalDB小改成InMemoryDB而已)

第二步打開Startup.cs, 並在下圖位置新增程式碼

services.AddLocalization(options => options.ResourcesPath = "Resources");

第三步新增Resources資料夾, 並新增兩個資源檔案 "Controllers.MoviesController.resx" 和 "Controllers.MoviesController.en-US.resx" 如下圖 :

Controllers.MoviesController.resx檔案的內容如下(檔案名稱沒包含語系表示是預設語系):
Controllers.MoviesController.en-US.resx檔案的內容如下(en-US表示英語系):
以上表示系統是英語語系,  "Hello" 會轉換成 "Hello(en-US,Movies)" 來顯示, 正常應該是轉換成  "Hello" 就好, 我多顯示其他文字只是用來知道這個 "Hello" 是由哪個語系檔案轉換來的而已
非英語系的 "Hello" 則會轉換成 "Hello(Default,Movies)" 來顯示, 表示是從預設檔案而來

以上第二以及第三兩個步驟是多國語系的共通步驟, 過來才是 Controller 的部分

第四步驟則是打開 MoviesController.cs 檔案, 改成 :

private readonly MvcMovieContext _context;
  
private readonly IStringLocalizer<moviescontroller> _localizer;    // 新增的部分
  
public MoviesController(MvcMovieContext context, IStringLocalizer<moviescontroller> localizer)    // 修改的部分
{
	_context = context;
	_localizer = localizer;    // 新增的部分
}

// GET: Movies
public async Task<iactionresult> Index()
{
	// 新增的部分
	ViewBag.msg = $"CurrentCulture : {CultureInfo.CurrentCulture.Name}"
		 + $"CurrentUICulture : {CultureInfo.CurrentUICulture.Name}"
		 + $"Hello : {_localizer["Hello"]}"
		 + $"Today : {DateTime.Now}";

	return View(await _context.Movie.ToListAsync());
}

以上的 _localizer["Hello"] 會將 "Hello" 轉換成對應的語系文字
而 DateTime.Now 也會自動轉換成對應的語系時間格式

第五步開啟 View\Movies\Index.cshtml 檔案
加入一行 @Html.Raw(ViewBag.msg), 如下圖 :

接著執行此專案, 看 Movies 的網頁 (我的電腦網址是 https://localhost:44310/Movies, 每個人的Port 會不同), 結果如下 :
CurrentCulture : zh-TW (繁體中文)
CurrentUICulture : zh-TW (繁體中文)
Hello : Hello(Default,Movies) (因為沒有繁體語系所以用預設顯示)(由_localizer["Hello"]而來)
Today : 2021/03/07 23:31:22 (繁體語系之日期顯示)

CurrentCulture :用來決定語系的日期、數值、貨幣格式,比較和排序(資料可以參考 : 多國語系 - 了解文化特性)
CurrentUICulture : 文字的語系


如果我在Resources路徑下加入 Controllers.MoviesController.zh-TW.resx 檔案(zh-TW表示繁體中文), 內容如下 :

再一次執行專案, 結果如下:
會發現 Hello 的部分變成:
Hello : 哈囉(zh-TW,Movies)

第六步
目前都只是判斷本機的語言系統, 並未依照使用者瀏覽器的語系來顯示, 而且無法隨時切換語系,
要做到這個功能, 就必須修改 Startup.cs 這個檔案
在ConfigureServices副程式中新增下列程式碼 : 
services.Configure<RequestLocalizationOptions>(options =>
{
	var supportedCultures = new[] { "en-US", "zh-TW" }; // 要支援的語系
	options
		.AddSupportedCultures(supportedCultures)    // 讓日期、貨幣格式支援語系
		.AddSupportedUICultures(supportedCultures); // 讓文字支援語系
});

在Configure副程式中新增下列程式碼 : 
app.UseRequestLocalization();

再執行專案, 試著在 URL 後面加上 ?culture=en-us (如 : https://localhost:44310/Movies?culture=en-us), 結果如下 :

結果繁體中文都變成英文了

多國語系的 Controller 部分就完成了


執行環境 : Windows 10 專業版 20H2, 19042.804
工具 : Visual Studio 2019 16.8.5
.Net 版本 : 5.01

留言

這個網誌中的熱門文章

Excel VBA (二) : 自訂函數之自動加總(續)

繼續上篇的 Excel VBA (一) : 自訂函數之自動加總 來修改程式 加總時如果要將非數字的全部濾掉, 我利用 TypeName 這個函數來完成, 再將Excel的C欄資料除了文字型別以外, 加上日期以及布林型別, 測試結果如下 Function 我的加總(加總區域 As Range) As Double Dim data As Variant 我的加總 = 0 For Each data In 加總區域 If TypeName(data.Value) = "Double" Then 我的加總 = 我的加總 + data End If Next End Function 如果我現在很懶, 懶得選擇加總區域, 讓它自動將它上方的資料自動加總起來, 例如在A10中輸入自訂函數, 則會自動將A1到A9的儲存格都加總起來, 我的懶人程式如下 : Function 我的加總2() As Double Dim 目前儲存格 As Range Dim 目前列 As Integer Dim i As Integer Set 目前儲存格 = Application.Caller 目前列 = 目前儲存格.Row 我的加總2 = 0 For i = 1 To 目前列 - 1 Set 目前儲存格 = 目前儲存格.Offset(-1, 0) If TypeName(目前儲存格.Value) = "Double" Then 我的加總2 = 我的加總2 + 目前儲存格 End If Next End Function Application.Caller : 會取得函數計算的儲存格, 它的行跟列可以透過Column跟Row來取得 ( 參考文章 ) 加總則是從同欄的第一列開始加, 一直加到輸入的前一列, 也就是 Application.Caller.Row - 1 offset(-1,0) : 則表示要位移的位置, -1 表示垂直往上一格, 0 表示水平維持不變 我在A10輸入自...

Excel C# (一) : 增益集 (Add-Ins) 之自訂函數

Excel的自訂函數除了之前介紹的VBA方式外, 還可以用 JavaScript, C# 等, 我就來試試看用C#來開發 我爬文找到了這篇 Excel-DNA 裡有詳細的教學, 不過我還是自己照做一遍看看是否成功 ! 第一步先開啟 Visual Studio 2019, 專案選擇 "類別庫(.NET Framework)" 過來將專案名稱輸入 MyExcelAddIns, 其他不變按下 "建立" 第二步接著在 "工具"->"NuGet 套件管理員"->"管理方案的 NuGet 套件", 將 Excel-DNA 套件加入至專案中 第三步將專案中的 Class1.cs 檔案刪除, 自己新增一個類別 "MyFunctions", 然後我複製 https://excel-dna.net 該網站上的範例, 貼進來方便測試 第四步我則是將方案組態由 "Debug" 改成 "Release"(如上圖的紅框), 再按 "建置" 下的 "重建方案" 產生 Excel XLL 檔案, 再去方案總管的 MyExcelAddIns 上按右鍵, 選擇 "在檔案總管中開啟資料夾" 會看到下面第二張圖 過來我的習慣是將這個 Release 目錄整個複製, 貼到桌面方便測試 ! 第五步則是開啟空白的Excel, 按 "程式開發人員" 下的 "Excel增益集", 點擊瀏覽後, 選擇桌面上我剛剛的 Release 資料夾, 如果Excel是32位元則選 MyExcelAddIns-AddIn.xll 檔案, 如果是64位元版本則選擇 MyExcelAddIns-AddIn64.xll 檔案, 接著在 Excel 任一儲存格輸入 =SayHello("World!"), 結果出現 Hello World!, 表示一切都正確, 接著我可以開始建立自己的函數了! 最後我個人認為自訂函數的VBA與C#兩種方式, 其優缺點如下:VBA的優點...

Asp.Net Core Debug Source Code

寫過Asp.Net Core Web MVC應該知道裡面要使用很多的Middleware,如果要知道裡面的運作方式,就要看Source Code,或者想知道自己寫的程式哪裡出問題,有時候就必須Debug進Source Code中看變數的變化 如何Debug Source Code我是參考 DEBUGGING ASP.NET CORE 2.0 SOURCE CODE 這篇文章來設定的,作法如下: 1.點選[工具]的[選項]  2.展開[偵錯]的[一般],並將[啟用Just My Code]的選取方塊 取消 ,以及[啟用來源連接支援]的選取方塊 點選起來   3.接著點選[偵錯]的[符號],並將[Microsoft伺服器]的選取方塊 點選起來  (點選之後會出現提示視窗,因為載入這些符號,會導致一些效能上的影響,尤其是首次載入,讓我以為Visual Studio當機了...) 這樣就可以Debug Source Code了,接著開始測試看看 : 1.先開啟一個新的專案(我選擇Asp.Net Core Web 應用程式) 2.因為只是測試所以都用預設的, 一直按確定就好, 除了Asp.Net Core 3.1改成5.0(操作方式都一樣沒差, 我只選5.0只是為了節省下載符號的時間以及空間而已,如果我選3.1它會下載這個版本的符號一次, 下次我選5.0它又會下載這個版本的符號一次) 3.專案自動建好後, 於視窗右邊的 HomeController.cs 按兩下, 視窗左邊就會看到檔案的內容, 接著找到 Index 的 rertrn View(), 在這列的前面點一下即可設定中斷點, 就像下圖的左邊紅色圈圈一樣(因為要顧到初學者所以才會說的這麼仔細) 4.設定好中斷點(紅色圈圈)之後, 過來就按下 [ IIS Express ] 的執行(上圖中中間上面的黃色圈起來的地方), 或者按下 F5, 就會開始執行程式 5.如果是第一次執行, 可能會出現一個確認視窗, 要你確認是否IIS Express的SSL憑證?按下是即可, 下面一個視窗也請按是 6.接著畫面會停止不動像當機一樣, 不是當機只是第一次抓符號要很久, 只要耐心等候直到 return View() 由紅底變成黃底就跑完了, 黃色底的列代表程式目前執行到這,...