Обновление алгоритмов шифрования для зависимостей Swift

Я использую инфраструктуру безопасности MobSF с открытым исходным кодом для сканирования исходного кода моего проекта Swift и его зависимостей на наличие уязвимостей. Большинство вещей выглядят довольно хорошо, однако я обеспокоен тем, что это показывает мне, что алгоритмы шифрования (MD5, SHA1) в моих зависимостях недостаточно безопасны.

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

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

Ответы 1

Ответ принят как подходящий

Во-первых, это зависит от того, почему они используют эти алгоритмы. Для определенных целей MD5 или SHA-1 не вызывают проблем с безопасностью, и они могут быть необходимы для совместимости с существующими стандартами или обратной совместимости.

Например, PBKDF2 абсолютно безопасен, используя SHA-1 в качестве хэша. Ему не требуется очень сильная хэш-функция для обеспечения собственной безопасности. Это даже безопасно с использованием MD5. Переход на SHA-2 с PBKDF2 не повышает безопасность, это просто «гигиена безопасности», то есть «избегайте алгоритмов, у которых есть известные проблемы, даже если они находятся в вашем коде, даже если они не вызывают проблем в вашем конкретном случае использования». Гигиена безопасности — это хорошая практика, но это не то же самое, что безопасность.

Для других случаев использования безопасность хеш-функции имеет решающее значение. Если фреймворк аутентифицирует произвольные сообщения с помощью MD5, это полностью не работает. Не принимайте этот ответ, чтобы предположить, что алгоритмы не имеют значения. Они делают! Но не в каждом случае использования. И если вы хотите декодировать транзакции считывания кредитной карты, вам, вероятно, потребуется, чтобы DES был в вашем коде, который сломан ужасно, но он вам все равно понадобится, потому что именно так шифруются магнитные полосы. Это не делает ваш фреймворк «небезопасным».

Когда вы говорите «но они, кажется, настаивают на использовании устаревших алгоритмов», я предполагаю, что вы имеете в виду, что вы открыли PR, и они отклонили его, и в этом случае я предполагаю, что у них есть веская причина (например, обратная совместимость, когда нет реальной проблемы безопасности). ). Если нет, то, очевидно, первым шагом будет открытие PR.

Тем не менее, если вы хотите изменить это, потому что чувствуете, что существует реальная проблема безопасности, которую они не решат, или просто из соображений гигиены, то с CocoaPods вы должны разветвить проект, изменить его и указать на свою собственную версию, используя атрибут source для ключевое слово pod.

Поддерживая сам криптографический фреймворк, я часто получаю отчеты об ошибках, которые просто неверны от разработчиков, использующих эти сканеры. Убедитесь, что вы знаете, что сканер говорит вам и как оценивать результаты. Ложные срабатывания очень распространены с ними. Эти инструменты полезны, но вам нужно иметь некоторый опыт, чтобы читать их отчеты.

Спасибо, это было отличное объяснение!

jimBeaux27 22.03.2022 18:00

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