Как исправить уязвимость в зависимостях npm?

Я получил 18 уязвимостей, дав npm audit, затем выбрал ту, которая помечена как высокая.

вот его деталь,

  High            Denial-of-Service Memory Exhaustion                           

  Package         qs                                                            

  Patched in      >= 1.x                                                        

  Dependency of   google-search-scraper                                         

  Path            google-search-scraper > request > qs                          

  More info       https://nodesecurity.io/advisories/29 

похоже, что нам нужно обновить пакет запроса, поэтому по >npm i request я его установил.

Теперь, что дальше, команда аудита снова дает те же результаты

пожалуйста помоги ,

Спасибо

РЕДАКТИРОВАТЬ

Moderate        Prototype pollution                                           

  Package         hoek                                                          

  Patched in      > 4.2.0 < 5.0.0 || >= 5.0.3                                   

  Dependency of   botkit                                                        

  Path            botkit > botbuilder > jsonwebtoken > joi > hoek               

  More info       https://nodesecurity.io/advisories/566  

Вы пробовали использовать npm audit fix?

Spitzbueb 06.12.2018 11:56

Это связано: youtube.com/watch?v=0dgmeTy7X3I Если я правильно помню, докладчик упоминает саму интересующую уязвимость qs, хотя не говорит, как ее исправить.

YakovL 06.12.2018 13:28

да, но это не сработало. На самом деле у нас 18 различных уязвимостей

Rio 06.12.2018 13:29
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
3
1 622
1

Ответы 1

Как говорится в отчете, уязвимость qs была исправлена ​​в 1.x. Для последних версий request это не проблема. google-search-scraper имеет зависимость от request@~2.33.0, которая зависит от qs@~0.6.0. Независимо от того, какая версия request установлена ​​в проекте, google-search-scraper продолжит использовать версию 2.33.x, содержащую уязвимость.

google-search-scraper должен быть разветвлен и использоваться вместо исходного пакета, версия зависимости request должна быть обновлена ​​в вилке, например к request@^2.33.0. Дополнительно выпуск можно открыть в репозитории пакетов и дополнить PR.

спасибо за ответ, хорошо, это не проблема версии, тогда в чем проблема,

Rio 06.12.2018 13:35

Я уже разветвил и клонировал проект (который использует парсер поиска Google), так что теперь, как мне это сделать.

Rio 06.12.2018 13:38

Проблема в том, что google-search-scraper испорчен и жестко запрограммирован для использования уязвимой версии request. В данном контексте не имеет значения, является ли это вашим собственным проектом или разветвленным. Вам нужно специально форкнуть google-search-scraper и использовать его вместо официального.

Estus Flask 06.12.2018 13:51

Я отредактировал вопрос, указав еще на одну уязвимость, это, должно быть, проблема с версией, я установил ее с помощью> npm, я думаю, но она все равно не работает. пожалуйста, помогите, я никогда раньше не работал над этим

Rio 06.12.2018 14:38

Это не уязвимость. Выполняйте проверку работоспособности при оценке отчетов npm audit. См. stackoverflow.com/a/51852121/3731501. В любом случае, не стесняйтесь открывать проблемы в пакетах, которые вызывают проблемы аудита, если они возникают в последней версии пакета.

Estus Flask 06.12.2018 14:46

как сделать проверку работоспособности при проведении аудита npm, я не знал об этом, спасибо, что рассказали

Rio 06.12.2018 15:07

Просто проверьте, что на самом деле представляет собой заявленная «уязвимость», откуда она взялась и может ли она вообще повлиять на ваше приложение - напрямую или через вложенные зависимости. аудит - это грубый инструмент, который создает много шума, который не нужно исправлять в большинстве случаев, особенно проблемы, помеченные как «умеренные» или ниже.

Estus Flask 06.12.2018 16:17

Другие вопросы по теме