ASP.NET Core 3.1系列(11)——基于JSON文件的国际化多语言实现方法

32 篇文章 42 订阅

1、前言

前一篇博客介绍了基于资源文件(*.resx)的国际化多语言实现方法。但从个人角度来说,我并不是很喜欢这种做法,因为如果一个系统要支持5种国际语言,那么就代表一个Controller需要对应5个资源文件。而如果系统中有20Controller,则表示需要创建100个资源文件。另一方面,如果从项目迁移的角度来考虑,之前的老项目可能都是把某个语言中的所有文本信息都写在了一个文件里,如果使用资源文件来处理,可能并不利于项目的迁移。下面就开始介绍如何利用JSON文件来实现多语言。

2、创建JSON文件

首先创建一个Resources文件夹,然后添加两个JSON文件,如下图所示:

  • Language.zh-CN.json
  • Language.en-US.json
    在这里插入图片描述
    JSON文件中添加一些文本信息,代码如下所示:
{
    "Name": "姓名",
    "Gender": "性别",
    "Age": "年龄"
}
{
    "Name": "Name",
    "Gender": "Gender",
    "Age": "Age"
}

这里需要注意:由于JSON文件的默认编码格式为GB2312,这会导致在读取中文配置项时产生乱码,因此需要将这两个JSON文件的编码格式改为UTF-8格式,如下图所示:
在这里插入图片描述
在这里插入图片描述

3、创建多语言类

在基于资源文件实现多语言的方法中,我们需要在IStringLocalizer的泛型参数中注入一个控制器,比如HomeController,而现在我们需要注入的是一个Language类,如下图所示:
在这里插入图片描述
Language类不需要添加任何代码,如下所示:

namespace App
{
    /// <summary>
    /// 多语言类
    /// </summary>
    public class Language
    {

    }
}

4、多语言的实现

NuGet中引入My.Extensions.Localization.Json组件,注意选择2.1.0版本,如下图所示:

My.Extensions.Localization.Json

在这里插入图片描述

4.1、添加多语言服务

Startup.cs中添加JSON多语言的支持,代码如下所示:

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Localization;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using System.Collections.Generic;
using System.Globalization;

namespace App
{
    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddControllers();

            // 添加JSON多语言
            services.AddJsonLocalization(options =>
            {
                options.ResourcesPath = "Resources";
            });
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            // 中英文支持
            var supportedCultures = new List<CultureInfo>
            {
                new CultureInfo("en-US"),
                new CultureInfo("zh-CN"),
            };
            app.UseRequestLocalization(new RequestLocalizationOptions
            {
                DefaultRequestCulture = new RequestCulture("zh-CN"),
                SupportedCultures = supportedCultures,
                SupportedUICultures = supportedCultures
            });

            app.UseHttpsRedirection();
            app.UseRouting();
            app.UseAuthorization();
            app.UseEndpoints(endpoints =>
            {
                endpoints.MapControllers();
            });
        }
    }
}

4.2、注入IStringLocalizer接口

然后在Controller中注入IStringLocalizer接口即可。需要注意的是,这里的接口泛型参数需要改成Language类,代码如下所示:

using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Localization;

namespace App.Controllers
{
    [Route("api/[controller]/[action]")]
    [ApiController]
    public class HomeController : ControllerBase
    {
        private readonly IStringLocalizer<Language> localizer;

        /// <summary>
        /// 构造函数
        /// </summary>
        /// <param name="localizer"></param>
        public HomeController(IStringLocalizer<Language> localizer)
        {
            this.localizer = localizer;
        }

        /// <summary>
        /// 获取多语言
        /// </summary>
        /// <returns></returns>
        [HttpGet]
        public string Get()
        {
            return localizer.GetString("Name").Value + "\n" +
                   localizer.GetString("Gender").Value + "\n" +
                   localizer.GetString("Age").Value;
        }
    }
}

4.3、测试效果

4.3.1、基于URL

URL设置为https://localhost:5001/api/Home/Get?ui-culture=zh-CN,输出结果为中文:
在这里插入图片描述
URL设置为https://localhost:5001/api/Home/Get?ui-culture=en-US,输出结果为英文:
在这里插入图片描述

4.3.2、基于Cookie

在当前网页中添加一个Cookie,名称为.AspNetCore.Culture,值为c=zh-CN|uic=zh-CN,输出结果为中文:
在这里插入图片描述
.AspNetCore.Culture的值改为c=en-US|uic=en-US,输出结果为英文:
在这里插入图片描述

4.3.3、基于请求头Header

将浏览器设置为中文模式,输出结果为中文:
在这里插入图片描述
将浏览器设置为英文模式,输出结果为英文:
在这里插入图片描述

5、结语

本文主要介绍了基于JSON文件的国际化多语言实现方法。个人比较喜欢这种方式,因为不需要给每个Controller都配置好几个资源文件,而且JSON文件看起来更加直观,也更加易于编辑。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
### 回答1: ASP.NET Core 3.1是一个跨平台、高性能的开源框架,它可以帮助我们快速地构建Web应用程序。ASP.NET Core 3.1中文教程可以为初学者提供一个快速上手的指南,帮助他们了解和掌握该框架的各种功能。 在学习ASP.NET Core 3.1教程之前,我们需要了解一些基本的编程概念和技能, 包括C#语言的基础知识、MVC(Model View Controller)等常见的编程模式、以及前端技术如HTML、CSS和JavaScript等。此外,我们还需要对.NET Core框架有一定的了解,如.NET Core的概念、架构和基础组件等。 学习ASP.NET Core 3.1的教程需要深入理解其设计方案和特点,例如跨平台、高性能、依赖注入、实时通信等。此外,我们还需要熟悉其主要组件,如ASP.NET Core的中间件、MVC框架、Entity Framework Core等。 在学习ASP.NET Core 3.1的教程时,我们需要通过实践才能更好地理解其所涉及的技术和概念。因此,我们需要通过编写各种实际的Web应用程序和示例,来实践和掌握所学的技巧和知识。 总之,学习ASP.NET Core 3.1的中文教程需要较深的前置知识储备和实操经验,而且需要坚持不懈地学习和练习以提高自己的技能水平。 ### 回答2: ASP.NET Core 3.1是目前为止最新的ASP.NET Core版本,它是一个跨平台的Web应用程序开发框架。对于想要学习ASP.NET Core 3.1的开发者来说,中文教程是非常重要的。 现在,有很多中文教程可以帮助开发者快速入门ASP.NET Core 3.1。这些教程通常包括以下内容: 1. ASP.NET Core 3.1的基础知识:网页处理、路由、控制器等; 2. ASP.NET Core 3.1中的模型、视图和控制器; 3. 动作过滤器和特性; 4. 实体框架和数据库相关操作; 5. API设计和测试等。 这些教程通常包含实例和练习,能够帮助开发者深入理解ASP.NET Core 3.1的开发原理。另外,一些知名的在线教育平台,如网易云课堂等,也提供了ASP.NET Core 3.1的中文课程,有兴趣的开发者可以去尝试。 总的来说,学习ASP.NET Core 3.1需要投入时间和精力,但是中文教程能够让初学者更加轻松地掌握ASP.NET Core 3.1的开发技能,更好地进行ASP.NET Core 3.1的开发工作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值