是否在ASP.NET Core中获取浏览器语言?

Get browser language in ASP.NET Core?(是否在ASP.NET Core中获取浏览器语言?)
本文介绍了是否在ASP.NET Core中获取浏览器语言?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试从浏览器获取默认语言,并使用以下代码获取它:

var languages = HttpContext.Request.UserLanguages;

由于我测试的.NET Core 2不支持上述功能:

var requestContext = Request.HttpContext.Features.Get<IRequestCultureFeature>();

但是,它返回NULL。获取该语言的正确方法或替代方法是什么?

推荐答案

IRequestCultureFeature提供您的应用程序支持的第一种匹配语言。支持的语言声明在您的Startup类的Configure()中定义(请参阅example)。如果您仍然需要所有接受的语言作为简单的string[],就像旧的Request.UserLanguages属性一样,那么使用Microsoft.AspNetCore.Http命名空间中定义的HeaderDictionaryTypeExtensions.GetTypedHeaders()扩展:

// In your action method.
var languages = Request.GetTypedHeaders()
                       .AcceptLanguage
                       ?.OrderByDescending(x => x.Quality ?? 1) // Quality defines priority from 0 to 1, where 1 is the highest.
                       .Select(x => x.Value.ToString())
                       .ToArray() ?? Array.Empty<string>();
数组languages包含根据优先级参数q接受的语言列表。具有最高优先级的语言排在第一位。要获取默认语言,请获取数组的第一个元素languages

作为扩展方法:

using System.Collections.Generic;
using System.Linq;

using Microsoft.AspNetCore.Http;

public static class HttpRequestExtensions
{
    public static string[] GetUserLanguages(this HttpRequest request)
    {
        return request.GetTypedHeaders()
            .AcceptLanguage
            ?.OrderByDescending(x => x.Quality ?? 1)
            .Select(x => x.Value.ToString())
            .ToArray() ?? Array.Empty<string>();
    }
}

这篇关于是否在ASP.NET Core中获取浏览器语言?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)