Какой ценой достигается надёжность Java приложений?

Новые версии Java нацелены на усиление безопасности и стабильности за счёт ограничений доступа к низкоуровневым и небезопасным API. Концепция «целостность по умолчанию» означает, что по умолчанию всё должно быть защищено от несанкционированного доступа. Разработчикам необходимо явно разрешать доступ к «опасным» функциям, что служит защитой от непреднамеренных уязвимостей и повышает надежность приложений.
Какой ценой достигается надёжность Java приложений?
Изображение носит иллюстративный характер

Старые методы, как sun.misc.Unsafe, позволяющие прямой доступ к памяти, постепенно выводятся из употребления из-за рисков нестабильности и проблем совместимости. Вместо них внедряются более безопасные альтернативы, такие как VarHandle API и Foreign Function and Memory API (FFM), которые предлагают более контролируемый способ работы с памятью и нативным кодом. Переход на новые API может повлиять на производительность, требуя от разработчиков тщательной оптимизации кода.

Java Native Interface (JNI) также подвергается ограничениям, так как позволяет нативному коду обходить проверки безопасности, создавая возможность утечек памяти и других проблем. FFM API выступает более безопасной заменой JNI, с более строгим контролем. Однако, разработчики должны быть осторожны и при его использовании, разрешая нативный доступ только тогда, когда это действительно необходимо, что также подразумевает использование соответствующих параметров запуска.

Эти изменения в Java требуют от разработчиков пересмотра подходов к кодированию, возможно даже переписывания части кода, и использования новых опций командной строки для отладки и тестирования. Эти меры направлены на обеспечение долгосрочной поддержки и надёжности приложений, требуя от разработчиков готовности к миграции на новые API и соблюдения новых правил безопасности.


Новое на сайте

19521Банковский троян VENON на Rust атакует Бразилию с помощью девяти техник обхода защиты 19520Бонобо агрессивны не меньше шимпанзе, но всё решают самки 19519Почему 600-килограммовый зонд NASA падает на Землю из-за солнечной активности? 19518«Липовый календарь»: как расписание превращает работников в расходный материал 19517Вредоносные Rust-пакеты и ИИ-бот крадут секреты разработчиков через CI/CD-пайплайны 19516Как хакеры за 72 часа превратили npm-пакет в ключ от целого облака AWS 19515Как WebDAV-диск и поддельная капча помогают обойти антивирус? 19514Могут ли простые числа скрываться внутри чёрных дыр? 19513Метеорит пробил крышу дома в Германии — откуда взялся огненный шар над Европой? 19512Уязвимости LeakyLooker в Google Looker Studio открывали доступ к чужим базам данных 19511Почему тысячи серверов оказываются открытой дверью для хакеров, хотя могли бы ею не быть? 19510Как исследователи за четыре минуты заставили ИИ-браузер Perplexity Comet попасться на... 19509Может ли женщина без влагалища и шейки матки зачать ребёнка естественным путём? 19508Зачем учёные из Вены создали QR-код, который невозможно увидеть без электронного... 19507Девять уязвимостей CrackArmor позволяют получить root-доступ через модуль безопасности...
Ссылка