1. 程式人生 > >ASP.NET Core MVC 中實現中英文切換

ASP.NET Core MVC 中實現中英文切換

  哈嘍..大家好 很久沒有更新了,今天就來一篇最近開發用到的功能,那就是中英文切換,這個實際上也不是高大上,先說一下原理,在.NET Core框架中給我們提供了全球化的類,叫做Localization,其官方的文件地址傳送門。

  在我的專案中,我是這樣操作的,你想用別的方式,也可以看文件自己去搞。這個已經不是什麼新鮮的東西了,只是網上的實現有些問題,不容易明白。

  我們無需任何Nuget包,因為它是在 Microsoft.AspNetCore.Mvc.Localization 中,那麼我們直接在.NET Core 框架中新增 Localization 服務。

public void ConfigureServices(IServiceCollection services)
        {
            services.AddLocalization(options => options.ResourcesPath = "Resources");
            services.AddMvc()
                .AddViewLocalization(LanguageViewLocationExpanderFormat.Suffix);
            services.Configure<RequestLocalizationOptions>(opts =>
                {
                    var supportedCultures = new List<CultureInfo>{
                        new CultureInfo("en-US"),
                        new CultureInfo("zh-CN")};
                        opts.SupportedCultures = supportedCultures;
                        opts.SupportedUICultures = supportedCultures; 
                        opts.RequestCultureProviders = new List<IRequestCultureProvider>{
                           new X_DOVERequestCultureProvider()
                        };
                });
            services.AddControllersWithViews();
        }

  嗯,這個程式碼是.NET Core 3.1 的 應該不會有太大區別吧?那個 X_DOVERequestCultureProvider 是我們自定義實現的,寫入了一些規則,我們看一下。

public class X_DOVERequestCultureProvider : RequestCultureProvider
    {
        public override Task<ProviderCultureResult> DetermineProviderCultureResult(HttpContext httpContext)
        {
            var CULTURE_String = "CULTURE";
            var CultureCookie = httpContext.Request.Cookies[CULTURE_String]?.ToString() ?? "";
            if (string.IsNullOrWhiteSpace(CultureCookie))
            {
                CultureCookie = "zh-CN";
                httpContext.Response.Cookies.Append(key: CULTURE_String, value: CultureCookie, options: new CookieOptions() { Expires = DateTime.Now.AddYears(1) });
            }
            return Task.FromResult(new ProviderCultureResult(CultureCookie));
        }
    }

  首先我們應該知道 RequestCultureProvider ,它是一個在框架自身包括的 .net core 提供的,我們繼承它重寫了它的抽象類,在其中獲取了httpContext的Cookies值,然後進行判斷,如果沒有咱們就不給它進行一個輸出了,否則它還是我們的zh-CN 就是中文。

  對,別忘記了要在Configure中使用中間價

            app.UseRequestLocalization(
                options:app.ApplicationServices
                .GetService<IOptions<RequestLocalizationOptions>>().Value);

  隨後我們應該定義我們的配置檔案,建立一個資料夾,放進去,它應當和上面Startup中的資料夾相同,隨後建立對應的檢視位置,一個英文一箇中文,一定要注意後面對應的en-Us 和 zh-CN 要相同哦。

  就現在我們在檢視中最上面匯入包,然後對應字典就可以了。

@using Microsoft.AspNetCore.Mvc.Localization
@inject IViewLocalizer Localizer

<section class="copyright"> @Localizer["section1"]  <a href="https://github.com/zaranetCore/amusinghoS"> | GitHub</a></section>

  你肯定知道該怎麼辦了,對的你可以去修改Cookies來操作當前httpContext中的合約,但儘管如何,我們只是重寫了cookies的,還沒有重寫url的,

<script>
    $(function () {
        $("#language").change(function (e) {
            var opt = $("#language").val();
            if (opt == 1) {
                document.cookie = 'CULTURE=zh-CN';
                location.reload();
            } else if(opt == 2) {
                document.cookie = 'CULTURE=en-US';
                location.reload();
            }
        });
    });
</script>

  好吧,歡迎各位同學把重寫url的方法寫寫出來,回覆在本篇文章中..我們看一下效果,好的就這樣吧..