Sobes.tech
Back to questions
Middle+
4

Посмотрите на этот код с SSR и singleton i18n классом. Найдите серьёзную проблему, которая может испортить HTML, отдаваемый пользователю. Как её исправить?

Companies where asked
Mayflower

Answer from AI

sobes.tech AI

Проблема с singleton i18n классом в SSR заключается в том, что состояние локализации хранится глобально и разделяется между всеми запросами. Это приводит к тому, что при параллельных запросах пользователи могут получить HTML с неправильным языком — данные локализации могут перезаписываться.

Как исправить:

  • Не использовать singleton для хранения состояния локализации.
  • Создавать отдельный экземпляр i18n для каждого запроса, чтобы локализация была изолирована.
  • Передавать нужный язык явно в функции рендеринга.

Пример:

function createI18n(lang) {
  return new I18n(lang);
}

app.get('*', (req, res) => {
  const i18n = createI18n(req.language);
  const html = renderApp({ i18n });
  res.send(html);
});

Так мы избегаем гонок и гарантируем корректный язык для каждого пользователя.