需要一个关于如何从Accept-Language请求标头中获取首选语言的示例

时间:2012-03-29 14:50:54

标签: c# java php .net

我需要一个代码示例或库来解析Accept-Language标头并返回我首选语言。 RFC2616声明:

  

Accept-Language请求标头字段类似于Accept,但是   限制首选的自然语言集   对请求的回应。语言标签在3.10节中定义。

   Accept-Language = "Accept-Language" ":"
                     1#( language-range [ ";" "q" "=" qvalue ] )
   language-range  = ( ( 1*8ALPHA *( "-" 1*8ALPHA ) ) | "*" ) 
     

每个语言范围可以给出相关的质量值   表示用户对语言的偏好的估计   由该范围指定。质量值默认为“q = 1”。

进一步的阅读表明,有太多的“可选”,“应该”,“可能”和其他转动的言论阻止我重新发明轮子 - 我想知道的是用户喜欢的语言,任何浏览器都会回答这个问题每天问题十亿次。

任何语言的任何代码片段(请使用Lisp和Assembler除外)都会有所帮助。

非常感谢提前!

2 个答案:

答案 0 :(得分:33)

<强>解决方案:

namespace ConsoleApplication
{
    using System;
    using System.Linq;
    using System.Net.Http.Headers;

    class Program
    {
        static void Main(string[] args)
        {
            string header = "en-ca,en;q=0.8,en-us;q=0.6,de-de;q=0.4,de;q=0.2";
            var languages = header.Split(',')
                .Select(StringWithQualityHeaderValue.Parse)
                .OrderByDescending(s => s.Quality.GetValueOrDefault(1));
        }
    }
}

<强>结果:

enter image description here

答案 1 :(得分:1)

试试这个,它在PHP中使用相同的正则表达式我确信它适用于任何语言:

$langs = array(); // used to store values

if (isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])) {
    // break up string into pieces (languages and q factors)
    preg_match_all('/([a-z]{1,8}(-[a-z]{1,8})?)\s*(;\s*q\s*=\s*(1|0\.[0-9]+))?/i', $_SERVER['HTTP_ACCEPT_LANGUAGE'], $lang_parse);

    if (count($lang_parse[1])) {
        // create a list like "en" => 0.8
        $langs = array_combine($lang_parse[1], $lang_parse[4]);

        // set default to 1 for any without q factor
        foreach ($langs as $lang => $val) {
            if ($val === '') $langs[$lang] = 1;
        }

        // sort list based on value 
        arsort($langs, SORT_NUMERIC);
    }
}

首先生成一个首选语言的排序数组:

Array
(
    [en-ca] => 1
    [en] => 0.8
    [en-us] => 0.6
    [de-de] => 0.4
    [de] => 0.2
)

来自示例ACCEPT_LANGUAGE标题:en-ca,en;q=0.8,en-us;q=0.6,de-de;q=0.4,de;q=0.2

Working example here