node服务端根据浏览器语言设置环境

目的:用户第一次进来。根据浏览器语言设置语言环境。

问题:1.浏览器权重q 跟语言是否是默认浏览器语言并无关系。只是设置的浏览器语言的排序。但一般正常来讲,获取到的第一个语言一般为浏览器语言。

      2.个别浏览器会有获取不到的情况。

方案:如果用户的url参数没有lang,也无cookie信息,则通过浏览器语言('accept-language')设置网站语言环境。一般中文,包括简体和繁体均以zh开头

代码:

const browserLang = ctx => {
  const langs = ctx.header['accept-language'];
  logger.info('获取到的浏览器语言', langs)
  let lang = 'en_US'
  if (langs && langs.startsWith('zh')) {
    lang = 'zh_CN'
  }
  logger.info('第一次设置语言', lang)
  return lang
}

const getLangFormat = ctx => {
  const langs = ['zh_CN', 'en_US', 'ru_RU']
  const lang = ctx.query.lang || ctx.cookies.get('Lang') || browserLang(ctx)
  const realLang = langs.includes(lang) ? lang : 'zh_CN'

  const cookieOptions = {
    httpOnly: false,
    domain: process.env.COOKIE_DOMAIN,
    expires: new Date(2147483647000)
  }

  ctx.cookies.set('Lang', realLang, cookieOptions)

  return realLang
}

  

posted @ 2019-03-27 10:59  李元夕cool  阅读(575)  评论(0编辑  收藏  举报