ASP.Net Core 2.0 Web应用程序中的本地化

时间:2018-01-16 16:11:22

标签: c# localization asp.net-core-2.0 globalization razor-pages

我正在尝试全球化,并将我的ASP.NET Core 2.0 Web应用程序本地化为西班牙语。我试图关注docs,但看起来这些文档似乎不适用于Core 2.0,因为它们似乎并不适用于Razor Pages。只有控制器&视图。然而,无论我是更改请求标头中的文化,还是使用文档中显示的查询字符串,本地化都不起作用。对我做错了什么的任何见解?

 http://localhost:26417/?culture=es&ui-culture=es

Startup.cs

public void ConfigureServices( IServiceCollection services )
{
    services.AddDbContext<PartDbContext>(options =>
            options.UseSqlServer(Configuration.GetConnectionString("PartDatabase"))
        );

    services.AddAuthentication(IISDefaults.AuthenticationScheme);

    services.AddLocalization(options => options.ResourcesPath = "Localization");
    services.AddMvc()
        .AddRazorPagesOptions(options => {
            //options.Conventions.AllowAnonymousToPage("/Index");
            // I can just use [AllowAnonymous] attribute
        })
        .AddViewLocalization()
        .AddDataAnnotationsLocalization();
}

// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure( IApplicationBuilder app, IHostingEnvironment env )
{
    if (env.IsDevelopment())
    {
        app.UseDeveloperExceptionPage();
        app.UseBrowserLink();
    }
    var supportedCultures = new []
    {
        new CultureInfo("en"),
        new CultureInfo("es"),
    };
    app.UseRequestLocalization(new RequestLocalizationOptions {
        DefaultRequestCulture = new Microsoft.AspNetCore.Localization.RequestCulture("en"),
        SupportedCultures = supportedCultures,
        SupportedUICultures = supportedCultures
    });
    app.UseStaticFiles();
    app.UseMvc(routes => {
        routes.MapRoute(name: "default", template: "{controller}/{action=Index}/{id?}");
    });
}

_ViewImports.cshtml

@using PartDatabase
@using Microsoft.Extensions.Configuration
@using Microsoft.AspNetCore.Authorization
@using Microsoft.AspNetCore.Mvc.Localization
@namespace PartDatabase.Pages
@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers
@inject IConfiguration Configuration
@inject  IAuthorizationService AuthorizationService
@inject IViewLocalizer Localizer

_Layout.cshtml

<a class="navbar-brand" asp-page="/Index">@Localizer["Part Database"]</a>

文件结构

enter image description here

资源文件

enter image description here

注意:

  • 我尝试将_Layout.es.resx移动到Localization文件夹的根目录。
  • 我尝试过使用&#34;资源&#34;作为名称而不是名称&#34;本地化&#34;正如他们在文档中所示,但我想相信行options.ResourcesPath = "Localization"使用不同的文件夹名称来照顾我。

1 个答案:

答案 0 :(得分:4)

我从未让ViewLocalizer在布局页面中工作,它似乎只适用于实际视图。要在_Layout.cshtml中使用本地化字符串,这就是我必须要做的事情。

1。创建一个虚拟类

这是为了能够稍后查找资源文件。资源文件的路径应反映您放置此文件的位置。例如,如果您将虚拟文件放在Models/_Shared.cs中,则资源文件应位于Resources/Models/_Shared.es.resx

namespace WebApp.Models
{
    // dummy class for shared resource strings
    public class _Shared
    {
    }
}

2。在IHtmlLocalizer

中注入_ViewImports.cshtml

(或者只是把它放在_Layout.cshtml的顶部)

@inject IHtmlLocalizer<Models._Shared> SharedLocalizer

3。使用SharedLocalizer中的_Layout.cshtml代替Localizer

SharedLocalizer也可以在其他视图中使用,您需要使用相同的共享资源,而不是在不同的资源文件中复制翻译。

<a class="navbar-brand" asp-page="/Index">@SharedLocalizer["Part Database"]</a>

更新:已验证这适用于Razor Pages项目。