前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ASP.NET Core之多语言配置

ASP.NET Core之多语言配置

作者头像
跟着阿笨一起玩NET
发布2021-06-17 18:44:36
1.4K0
发布2021-06-17 18:44:36
举报

介绍

支持多语言使网站可以覆盖更广泛的受众。 ASP.NET Core 提供的服务和中间件可将网站本地化为不同的语言。

本次示例环境:vs2019、net5

配置

无需引用Nuget包即可实现以下功能。

注入容器

代码语言:javascript
复制
services.AddLocalization(t =>
{
    t.ResourcesPath = "Language";
});

启用配置

代码语言:javascript
复制
            var supportedCultures = new List<CultureInfo>()
            {
                new CultureInfo("zh-CN"),
                new CultureInfo("en-US")
            };
            app.UseRequestLocalization(new RequestLocalizationOptions
            {
                //这里指定默认语言包
                DefaultRequestCulture = new RequestCulture("en-US"),//为了测试配置默认语言英文
                SupportedCultures = supportedCultures,
                SupportedUICultures = supportedCultures
            });

语言配置文件

需要在根目录新建一个文件夹,文件夹名字就是ResourcesPath的名字。资源文件(resx结尾)存放路径需要和使用的地方目录结构一致。(右键文件夹>添加>新建项)

image-20210511223406104
image-20210511223406104

image-20210511223406104

语言包下的目录结构和MVC对应,控制器对应控制器,视图对应视图。资源文件命名方式为使用文件的文件名称加上语言代码。

image.png
image.png

image.png

读取资源文件

在控制器中使用,依赖注入资源文件

代码语言:javascript
复制
    [ApiController]
    [Route("[controller]")]
    public class HomeController : ControllerBase
    {
        private readonly IStringLocalizer<HomeController> _localizer;

        public HomeController(IStringLocalizer<HomeController> localizer)
        {
            _localizer = localizer;
        }

        [HttpGet]
        public string Get()
        {
            return _localizer["succeed"].Value;//如果找不到succeed的本地化值,那么就返回字符串“succeed”
        }
    }

测试

有多种方法可以告诉程序需要使用哪一个语言文件,下面只说常见的使用,还支持自定义 。

默认输出

image.png
image.png

HTTP报文

和常见的请求一样添加Accept-Language请求头即可

代码语言:javascript
复制
Accept-Language:zh-CN
image.png
image.png

Cookie

默认使用cookie名称.AspNetCore.Culture,值是

代码语言:javascript
复制
c=zh-CN|uic=zh-CN
c=zh-CN
uic=zh-CN

c是Culture,uic是UICulture

URL参数

三种写法,效果一样

代码语言:javascript
复制
?culture=zh-CN&ui-culture=zh-CN
?culture=zh-CN
?ui-culture=zh-CN
image.png
image.png

参考文档

https://docs.microsoft.com/zh-cn/aspnet/core/fundamentals/localization?view=aspnetcore-5.0

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-06-12 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 介绍
  • 配置
    • 注入容器
      • 启用配置
        • 语言配置文件
        • 读取资源文件
        • 测试
          • HTTP报文
            • Cookie
              • URL参数
              • 参考文档
              相关产品与服务
              消息队列 TDMQ
              消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档