Сравнение криптографических библиотек - Comparison of cryptography libraries

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

Библиотеки криптографии

ВыполнениеКомпанияЯзык разработкиОткрытый исходный кодЛицензия на программное обеспечениеПоследнее обновление
БотанДжек ЛлойдC ++даУпрощенный BSD2.16.0 (6 октября 2020 г.; 58 дней назад (2020-10-06)[1]) [±]
Надувной ЗамокЛегион Надувного Замка Inc.Java, C #даЛицензия MIT
Ява1.67 / 1 ноября 2020 г.; 32 дней назад (2020-11-01)[2]
Java FIPSBC-FJA 1.0.2 / 24 августа 2019 г.; 15 месяцев назад (2019-08-24)[3]
C #1.8.8 / 22 сентября 2020 г.; 2 месяца назад (2020-09-22)[4]
C # FIPSBC-FNA 1.0.1 / 28 декабря 2016 г.; 3 года назад (2016-12-28)[5]
cryptlibПитер ГутманнCдаЛицензия Sleepycat или коммерческая лицензия3.4.5 (2019; 1 год назад (2019)[6]) [±]
Крипто ++Проект Crypto ++C ++даЛицензия на программное обеспечение Boost (все отдельные файлы всеобщее достояние )22 февраля 2019 г. (8.1.0)
GnuTLSНикос Маврогианнопулос, Симон ЙозефссонCдаGNU LGPL v2.1 +3.6.14 (3 июня 2020 г.; 6 месяцев назад (2020-06-03)[7]) [±]
LibreSSLФонд OpenBSDCдаЛицензия Apache 1.015 июня 2020
LibgcryptGnuPG сообщество и g10codeCдаGNU LGPL v2.1 +1.8.7 (23 октября 2020 г.; 41 дней назад (2020-10-23)[8]) [±]
libsodiumФрэнк ДенисCдаЛицензия ISC30 мая 2019 г. (1.0.18)
NaClДэниел Дж. Бернштейн, Таня Ланге, Питер ШвабеCдаВсеобщее достояние21 февраля 2011 г.[9]
КрапиваCдаGNU GPL v2 + или GNU LGPL v33.5.1 (27 июня 2019 г.; 17 месяцев назад (2019-06-27)[10]) [±]
Услуги сетевой безопасности (NSS)MozillaCдаMPL 2.03.59 (13 ноября 2020 г.; 20 дней назад (2020-11-13)[11]) [±]

3.53.1 (16 июня 2020 г.; 5 месяцев назад (2020-06-16)[11]) [±]

OpenSSLПроект OpenSSLCдаЛицензия Apache 1.0 и лицензия BSD с 4 пунктами1.1.1h (22 сентября 2020 г.; 2 месяца назад (2020-09-22)[12]) [±]
RSA BSAFE Crypto-C Micro EditionDell, ранее RSA БезопасностьCНет[а]Проприетарный4.1.4 (11 сентября 2019 г.; 14 месяцев назад (2019-09-11)[13]) [±]
RSA BSAFE Крипто-JDell, ранее RSA БезопасностьЯваНет[а]Проприетарный6.2.5 (15 августа 2019 г.; 15 месяцев назад (2019-08-15)[14]) [±]
волкwolfSSL, Inc.CдаGPL v2 или коммерческая лицензия4.5.0 (19 августа 2020 г.; 3 месяца назад (2020-08-19)[15]) [±]
mbed TLSARM LimitedCдаЛицензия Apache 2.02.16.2 (11 июня 2019 г.; 17 месяцев назад (2019-06-11)[16]) [±]

2.7.10 (19 марта 2018 г.; 2 года назад (2018-03-19)[16]) [±]

ФемидаКазачьи лабораторииC; встроенные оболочки для C ++, Go, Objective-C, Swift, Java, PHP, Rust, JavaScript, Ruby, Python, WASM[17]даЛицензия Apache 2.00.13.5 (12 ноября 2020 г.; 21 дней назад (2020-11-12))[18]
  1. ^ а б Лицензия на исходный код RSA BSAFE была доступна для покупки, когда RSA Security продавала BSAFE.

Проверка FIPS 140

В этом разделе описывается статус FIPS 140 сертификация для перечисленных криптографических библиотек в соответствии с Программой валидации криптографических модулей NIST.[19]

ВыполнениеСертификат FIPS 140-2 подтвержденСертификат FIPS 140-3 подтвержден
БотанНетНет
Надувной Замокда[20]Нет
cryptlibНетНет
Крипто ++Нет[а]Нет
GnuTLSНетНет
LibgcryptНет[21][b]Нет
libsodiumНетНет
NaClНетНет
КрапиваНетНет
Услуги сетевой безопасности (NSS)Нет[22][c]Нет
OpenSSLВ процессе[23][d]Нет
RSA BSAFE Crypto-C Micro Editionда[24][e]Нет
RSA BSAFE Крипто-Jда[25][e]Нет
волкда[26]В процессе[27][f]
mbed TLSНетНет
ФемидаНетНет
  1. ^ Crypto ++ получил три проверки FIPS 140 с 2003 по 2008 год. В 2016 году NIST переместил Crypto ++ в Исторический список проверки. Этот шаг фактически отменяет проверку FIPS, и федеральные агентства не могут использовать модуль для проверенной криптографии.
  2. ^ Фактический модуль Libgcrypt не прошел проверку на соответствие стандарту FIPS 140-2 GnuPG, хотя проверки все еще существуют для версий Amazon Web Services, Oracle, SafeLogic, Hewlett Packard Enterprise и Red Hat.
  3. ^ Фактический модуль Network Security Services (NSS) не прошел проверку на соответствие стандарту FIPS 140-2 Mozilla, хотя проверки все еще существуют для версий Amazon Web Services, Oracle, Trend Micro, Cisco, Red Hat, SUSE, SafeLogic и Hewlett Packard Enterprise.
  4. ^ Фактический модуль OpenSSL был перемещен в список исторической проверки 1 сентября 2020 г. из-за прекращения поддержки FIPS 186-2, хотя проверки все еще существуют для версий от различных поставщиков. Этот шаг фактически отменяет проверку FIPS, и федеральные агентства не могут использовать модуль для проверенной криптографии. OpenSSL начал процесс проверки нового поставщика OpenSSL FIPS 3.0, который теперь отображается как «Тестируемая реализация» в CMVP, но временная шкала все еще не определена, и этот модуль еще не доступен для общественности.
  5. ^ а б RSA BSAFE был назначен на конец расширенной поддержки (EOXS), при этом все версии заканчивают все обновления 31 января 2022 года. https://www.dell.com/support/article/en-us/sln322390/product-version-life-cycle-for-rsa-bsafe?lang=en
  6. ^ Библиотека wolfCrypt находится в списке «Тестируемая реализация» на CMVP для FIPS 140-3.

Ключевые операции

Ключевые операции включают алгоритмы генерации ключей, соглашения об обмене ключами и стандарты криптографии с открытым ключом.

Генерация и обмен ключей

ВыполнениеECDHDHDSAЮАРЭль-ГамальНТРУDSS
БотандададададаНетда
Надувной Замокдадададададада
cryptlibдададададаНетда
Крипто ++дададададаНетда
Libgcryptда[а]дадададаНетда
libsodiumдаНетНетНетНетНетНет
КрапиваНетНетдадаНетНетНет
OpenSSLдадададаНетНетНет
RSA BSAFE Crypto-C Micro EditionдадададаНетНетНет
RSA BSAFE Крипто-JдадададаНетНетНет
волкдадададаНетдада
mbed TLSдадададаНетНетНет
Фемидада[28]НетНетдаНетНетНет
  1. ^ Используя интерфейс нижнего уровня.

Криптография на эллиптических кривых (ECC) поддерживать

ВыполнениеNISTSECGECC BrainpoolECDSAECDHПодкрутка25519EdDSAГОСТ Р 34.10
Ботандададададададада
Надувной Замокдададададададада
cryptlibдададададаНетНетНет
Крипто ++дадададададаНетНет
Libgcryptдададададададада
libsodiumдаНетНетНетНетдадаНет
КрапивадаЧастичноеНетНетНетдадаНет
OpenSSLдададададададада
RSA BSAFE Crypto-C Micro EditionдадаНетдадаНетНетНет
RSA BSAFE Крипто-JдадаНетдадаНетНетНет
волкдаНетдададададаНет
mbed TLSдадададададаНетНет
Фемидада[29]НетНетда[30]да[31]да[32][33]да[34][35]Нет

Стандарты криптографии с открытым ключом

ВыполнениеPKCS # 1PKCS # 5PKCS # 8PKCS # 12IEEE P1363ASN.1
БотандададаНетдада
Надувной Замокдададададада
cryptlibдадададаНетда
Крипто ++дадада[а]Нетдада
Libgcryptдада[b]да[b]да[b]да[b]да[b]
libsodiumНетНетНетНетНетНет
КрапивададаНетНетНетНет
OpenSSLдадададаНетда
RSA BSAFE Crypto-C Micro Editionдададададада
RSA BSAFE Крипто-JдадададаНетда
волкдадададаНетда
mbed TLSдаНетдадаНетда
ФемидаНетНетНетНетНетНет
  1. ^ По умолчанию библиотека предлагает кодирование X.509 и PKCS # 8 без PEM. Для PEM-кодирования открытых и закрытых ключей Пакет PEM необходим.
  2. ^ а б c d е Эти стандарты шифрования открытого ключа (PKCS) поддерживаются сопутствующими библиотеками и инструментами, которые также являются частью Фреймворк GnuPG, хотя и не самой библиотекой libgcrypt.

Хеш-функции

Сравнение поддерживаемых криптографические хеш-функции. На данный момент в этот раздел также включены шифры, которые используются для создания тега MAC для сообщения. Здесь хеш-функции определяются как принимающие сообщение произвольной длины и выдающие выходные данные фиксированного размера, которые практически невозможно использовать для воссоздания исходного сообщения.

ВыполнениеMD5SHA-1SHA-2SHA-3РИПЭМД-160ТигрВодоворотГОСТСтрибогBLAKE2
Ботандададададададададада
Надувной Замокдададададададададада
cryptlibдададададаНетдаНетНетНет
Крипто ++дадададададададаНетда
Libgcryptдададададададададада
libsodiumНетНетдаНетНетНетНетНетНетда
КрапивадададададаНетНетдаНетНет
OpenSSLдадададададададаНетда
RSA BSAFE Crypto-C Micro EditionдадададаНетНетНетдаНетНет
RSA BSAFE Крипто-JдададададаНетНетНетНетНет
волкдададададаНетНетНетНетда
mbed TLSдададададаНетНетНетНетНет
ФемидаНетНетда[36][37]НетНетНетНетНетНетНет

Алгоритмы MAC

Сравнение реализаций код аутентификации сообщения (MAC) алгоритмы. MAC - это короткий фрагмент информации, используемый для аутентификации сообщения, другими словами, чтобы подтвердить, что сообщение пришло от указанного отправителя (его подлинность) и не было изменено при передаче (его целостность).

ВыполнениеHMAC-MD5HMAC-SHA1HMAC -SHA2Поли1305-AESBLAKE2-MAC
Ботандадададада
Надувной Замокдадададада
cryptlibдададаНетНет
Крипто ++дадададада
Libgcryptдадададада
libsodiumНетНетдадада
КрапивададададаНет
OpenSSLдадададаНет
RSA BSAFE Crypto-C Micro EditionдададаНетНет
RSA BSAFE Крипто-JдадададаНет
волкдадададада
mbed TLSдададаНетНет
ФемидаНетНетда[38][39]НетНет

Блочные шифры

В таблице сравниваются реализации блочных шифров. Блочные шифры определяются как детерминированные и работают с заданным числом битов (называемых блоком) с использованием симметричного ключа. Каждый блочный шифр можно разбить на возможные размеры ключей и режимы блочного шифра, с которыми он может работать.

Блочный шифр алгоритмы

ВыполнениеAESКамелия3DESBlowfishTwofishCAST5ИДЕЯГОСТ 28147-89 / ГОСТ Р 34.12-2015.ARIA
Ботандадададададададада
Надувной Замок[40]дадададададададада
cryptlib[41]даНетдада
дада
Крипто ++дададададададаЧастичное[а]да
Libgcryptдададададададада
libsodiumЧастичное[b]НетНетНетНетНетНетНетНет
Крапивадададада
OpenSSLдадададаНетдададада
RSA BSAFE Crypto-C Micro EditionдададаНетНетНетНетЧастичное[c]да
RSA BSAFE Крипто-JдаНетдаНетНетНетНетНетНет
волкдададаНетНетНетдаНетНет
mbed TLSдадададаНетНетНетНетНет
Фемидада[42][43]НетНетНетНетНетНетНетНет
  1. ^ Crypto ++ поддерживает только ГОСТ 28147-89, но не ГОСТ Р 34.12-2015.
  2. ^ libsodium поддерживает только AES-256, но не AES-128 или AES-192.
  3. ^ RSA BSAFE Micro Edition Suite поддерживает только ГОСТ 28147-89, но не ГОСТ Р 34.12-2015.

Режимы шифрования

ВыполнениеЕЦБCBCOFBCFBCTRСККGCMOCBXTSAES-WrapТранслировать
БотанНетдададададададададада
Надувной Замокдададададададада
дада
cryptlibдададада
Нетда
Крипто ++дададададададаНетНетНетда
Libgcryptдадададададададададада
libsodiumНетНетНетНетдаНетдаНетНетНетНет
КрапивададаНетНетдададаНетНетНетНет
OpenSSLдадададададададададада
RSA BSAFE Crypto-C Micro EditionдададададададаНетдадада
RSA BSAFE Крипто-JдададададададаНетдадада
волкдадаНетдадададаНетдаНетда
mbed TLSдадаНетдадададаНетНетНетНет
ФемидаНетНетНетНетда[44][45]НетдаНетНетНетНет

Потоковые шифры

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

ВыполнениеRC4HC-256КроликСальса20ЧаЧаТЮЛЕНЬПанамаБУДИТЬЗерноVMPCИСААК
БотандаНетНетдадаНетНетНетНетНетНет
Надувной ЗамокдадаНетдадаНетНетНетдадада
cryptlibдаНетНетНетНетНетНетНетНетНетНет
Крипто ++дадададададададаНетНетНет
LibgcryptдаНетНетдадаНетНетНетНетНетНет
libsodiumНетНетНетдадаНетНетНетНетНетНет
КрапивадаНетНетдадаНетНетНетНетНетНет
OpenSSLдаНетНетНетдаНетНетНетНетНетНет
RSA BSAFE Crypto-C Micro EditionдаНетНетНетНетНетНетНетНетНетНет
RSA BSAFE Крипто-JдаНетНетНетдаНетНетНетНетНетНет
волкдададададаНетНетНетНетНетНет
mbed TLSдаНетНетНетНетНетНетНетНетНетНет
ФемидаНетНетНетНетНетНетНетНетНетНетНет

Аппаратная поддержка

В таблице сравнивается возможность использования аппаратной улучшенной криптографии. С помощью специального оборудования библиотека может достичь большей скорости и / или большей безопасности, чем в противном случае.

Интеллектуальная карточка, SIM и HSM поддержка протокола

ВыполнениеPKCS # 11ПК / SCCCID
БотандаНетНет
Надувной Замокда [а]НетНет
cryptlibдаНетНет
Крипто ++НетНетНет
Libgcryptда [46]да [47]да [47]
libsodiumНетНетНет
OpenSSLда [48]НетНет
RSA BSAFE Crypto-C Micro EditionдаНетНет
RSA BSAFE Крипто-Jда[b]НетНет
волкдаНетНет
mbed TLSда [48]НетНет
ФемидаНетНетНет
  1. ^ В сочетании с поставщиком PKCS # 11 или путем реализации операторских интерфейсов, обеспечивающих доступ к основным операциям.
  2. ^ При использовании RSA BSAFE Crypto-J в собственном режиме с использованием RSA BSAFE Crypto-C Micro Edition.

Общее назначение ЦПУ / поддержка ускорения платформы

ВыполнениеAES-NISSSE3 / SSE4.1AVX / AVX2RDRANDЧЕРЕЗ PadLockIntel QuickAssistAltiVec[а]ARMv7-A НЕОНИнструкции по криптографии ARMv8-A
БотандадададаНетНетдадада
cryptlibдададададаНетНетНетНет
Крипто ++дадададада[b]Нетдадада
Libgcrypt[49]дададададаНетНетдада
libsodiumдададаНетНетНетНетНетНет
OpenSSLдададада[c]даНетдадада
RSA BSAFE Crypto-C Micro EditionдадададаНетНетНетНетда
RSA BSAFE Крипто-Jда[d]да[d]да[d]да[d]НетНетНетНетда[d]
волкдадададаНетда[50]Нетдада[51]
Фемидада[52]дадададаНетдадада
  1. ^ AltiVec включает обработку SIMD от POWER4 до POWER8. POWER8 добавил шифрование в ядре, которое обеспечивает ускоренные AES, SHA и PMUL, аналогичные ARMv8.1.
  2. ^ Crypto ++ предоставляет доступ только к генератору случайных чисел Padlock. Других функций, вроде ускорения AES, не предусмотрено.
  3. ^ Поддержка OpenSSL RDRAND предоставляется через интерфейс ENGINE. Генератор RDRAND по умолчанию не используется.
  4. ^ а б c d е При использовании RSA BSAFE Crypto-J в собственном режиме с использованием BSAFE Crypto-C Micro Edition

Размер кода и соотношение кода и комментариев

ВыполнениеРазмер исходного кода

(kSLOC = 1000 строк исходного кода)

Соотношение строк кода и строк комментария
Ботан133[53]4.55[53]
Надувной Замок1359[54]5.26[54]
cryptlib2412.66
Крипто ++115[55]5.74[55]
Libgcrypt216[56]6.27[56]
libsodium44[57]21.92[57]
Крапива111[58]4.08[58]
OpenSSL472[59]4.41[59]
RSA BSAFE Crypto-C Micro Edition1117[а]4.04[а]
RSA BSAFE Крипто-J271[b]1.3[b]
волк395.69
mbed TLS105[60]33.9[60]
Фемида69[61]3.9[61]
  1. ^ а б На основе CCME 4.1.4, включая исходный код тестов. Создано с использованием https://github.com/XAMPPRocky/tokei
  2. ^ а б На основе Crypto-J 6.2.5, без исходных тестов. Создано с использованием https://github.com/XAMPPRocky/tokei

Портативность

ВыполнениеПоддерживаемая операционная системаПотокобезопасный
БотанLinux, Windows, macOS, Android, iOS, FreeBSD, NetBSD, OpenBSD, DragonflyBSD, AIX, QNX, Haiku, IncludeOSда
Надувной ЗамокОбщий API Java: J2ME, Java Runtime Environment 1.1+, Android. API Java FIPS: среда выполнения Java 1.5+, Android. C # API (общие и FIPS): CLR 4.
cryptlibAMX, ARINC 653, BeOS, ChorusOS, CMSIS-RTOS / mbed-rtos, DOS, DOS32, eCOS, embOS, FreeRTOS / OpenRTOS, uItron, MQX, MVS, Nucleus, OS / 2, Palm OS, QNX Neutrino, RTEMS, SMX , Tandem NonStop, Telit, ThreadX, uC / OS II, Unix (AIX, FreeBSD, HP-UX, Linux, macOS, Solaris и т. Д.), VDK, VM / CMS, VxWorks, Win16, Win32, Win64, WinCE / PocketPC / и т.д., XMKда
Крипто ++Unix (AIX, OpenBSD, Linux, MacOS, Solaris и др.), Win32, Win64, Android, iOS, ARMда[а]
LibgcryptВсе 32- и 64-битные системы Unix (GNU / Linux, FreeBSD, NetBSD, macOS и т. Д.), Win32, Win64, WinCE и другиеда[62]
libsodiummacOS, Linux, OpenBSD, NetBSD, FreeBSD, DragonflyBSD, Android, iOS, 32- и 64-битная Windows (Visual Studio, MinGW, C ++ Builder), NativeClient, QNX, JavaScript, AIX, MINIX, Solarisда
OpenSSLSolaris, IRIX, HP-UX, MPE / iX, Tru64, Linux, Android, BSD (OpenBSD, NetBSD, FreeBSD, DragonflyBSD), NextSTEP, QNX, UnixWare, SCO, AIX, 32- и 64-разрядная Windows (Visual Studio, MinGW , UWIN, CygWin), UEFI, macOS (Дарвин), iOS, HURD, VxWorks, uClinux, VMS, DJGPP (DOS), Haikuда
RSA BSAFE Crypto-C Micro EditionSolaris, HP-UX, Tru64, Linux, Android, FreeBSD, AIX, 32- и 64-битная Windows (Visual Studio), macOS (Darwin), iOS, VxWorksда
RSA BSAFE Крипто-JSolaris, Linux, Android, FreeBSD, AIX, 32- и 64-битная Windows, macOS (Darwin)да
волкWin32 / 64, Linux, macOS, Solaris, ThreadX, VxWorks, FreeBSD, NetBSD, OpenBSD, встроенный Linux, WinCE, Haiku, OpenWRT, iPhone (iOS), Android, Nintendo Wii и Gamecube через DevKitPro, QNX, MontaVista, NonStop, TRON / ITRON / µITRON, микроконтроллер Micrium / OS, FreeRTOS, SafeRTOS, Freescale MQX, Nucleus, TinyOS, HP-UXда
mbed TLSWin32 / 64, системы Unix, встроенный Linux, микроконтроллер Micrium / OS, FreeRTOS?
ФемидаDebian, Ubuntu, CentOS, RHEL, macOS, Windows (экспериментальная поддержка MSYS2), Android, iOS, ARM, WASM, React Native[63]да
  1. ^ Crypto ++ является потокобезопасным на уровне объекта, то есть между экземплярами нет общих данных. Если два разных потока обращаются к одному и тому же объекту, то за блокировку отвечает пользователь.

Рекомендации

  1. ^ «Ботан: примечания к выпуску». Получено 2020-10-29.
  2. ^ «Примечания к выпуску - bouncycastle.org». 2020-11-01. Получено 2020-11-01.
  3. ^ "Ресурсы Java FIPS - bouncycastle.org". 2019-08-24. Получено 2019-08-29.
  4. ^ "Легион надувного замка C # Cryptography API". 2020-09-22. Получено 2020-11-01.
  5. ^ "Ресурсы C # .NET FIPS - bouncycastle.org". 2016-11-11. Получено 2017-08-28.
  6. ^ Гутманн, Питер (2019). "Скачивание". cryptlib. Оклендский университет Школа компьютерных наук. Получено 2019-08-07.
  7. ^ "Библиотека безопасности транспортного уровня GnuTLS". Получено 30 июн 2020.
  8. ^ «Выпущен Libgcrypt 1.8.7». dev.gnupg.org. 2020-10-23. Получено 2020-10-24.
  9. ^ Скачивание и установка NaCl, Bernstein, Lange, Schwabe, получено 22 мая 2017 г.
  10. ^ "Файл журнала изменений Nettle @ git tag nettle_3.5.1_release_20190627".
  11. ^ а б «Примечания к выпуску для последних версий NSS». Сеть разработчиков Mozilla. 13 ноября 2020 г.. Получено 29 ноябрь 2020.
  12. ^ "OpenSSL: Журнал новостей". Получено 2020-09-22.
  13. ^ «RSA объявляет о выпуске RSA BSAFE® Crypto-C Micro Edition 4.1.4».
  14. ^ «RSA объявляет о выпуске RSA BSAFE® Crypto-J 6.2.5».
  15. ^ "wolfSSL ChangeLog". 2020-08-19. Получено 2020-08-22.
  16. ^ а б «Выпущен Mbed TLS 2.16.0, 2.7.9 и 2.1.18». 2018-12-21. Получено 2018-03-24.
  17. ^ «Языки Фемиды». Github. Получено 2020-11-22.
  18. ^ https://github.com/cossacklabs/themis/releases/tag/0.13.5
  19. ^ https://csrc.nist.gov/projects/cryptographic-module-validation-program/validated-modules/search
  20. ^ https://csrc.nist.gov/projects/cryptographic-module-validation-program/validated-modules/search?SearchMode=Basic&Vendor=bouncy+castle&CertificateStatus=Active&ValidationYear=0
  21. ^ https://csrc.nist.gov/projects/cryptographic-module-validation-program/validated-modules/search?SearchMode=Basic&ModuleName=libgcrypt&CertificateStatus=Active&ValidationYear=0
  22. ^ https://csrc.nist.gov/projects/cryptographic-module-validation-program/validated-modules/search?SearchMode=Basic&ModuleName=+NSS&CertificateStatus=Active&ValidationYear=0
  23. ^ https://csrc.nist.gov/projects/cryptographic-module-validation-program/modules-in-process/iut-list
  24. ^ https://csrc.nist.gov/projects/cryptographic-module-validation-program/validated-modules/search?SearchMode=Basic&Vendor=rsa&ModuleName=crypto-c+micro&CertificateStatus=Active&ValidationYear=0
  25. ^ https://csrc.nist.gov/projects/cryptographic-module-validation-program/validated-modules/search?SearchMode=Basic&ModuleName=crypto-j&CertificateStatus=Active&ValidationYear=0
  26. ^ https://csrc.nist.gov/projects/cryptographic-module-validation-program/validated-modules/search?SearchMode=Basic&ModuleName=wolfcrypt&CertificateStatus=Active&ValidationYear=0
  27. ^ https://csrc.nist.gov/projects/cryptographic-module-validation-program/modules-in-process/iut-list
  28. ^ https://github.com/cossacklabs/themis#cryptosystems
  29. ^ https://docs.cossacklabs.com/themis/spec/asymmetric-keypairs/ecc/
  30. ^ https://docs.cossacklabs.com/themis/crypto-theory/cryptosystems/secure-message/
  31. ^ https://docs.cossacklabs.com/themis/crypto-theory/cryptosystems/secure-message/
  32. ^ https://docs.cossacklabs.com/themis/crypto-theory/cryptosystems/secure-comparator/
  33. ^ https://www.cossacklabs.com/files/secure-comparator-paper-rev12.pdf
  34. ^ https://docs.cossacklabs.com/themis/crypto-theory/cryptosystems/secure-comparator/
  35. ^ https://www.cossacklabs.com/files/secure-comparator-paper-rev12.pdf
  36. ^ https://docs.cossacklabs.com/themis/architecture/soter/#data-integrity-and-authentication
  37. ^ https://github.com/cossacklabs/themis/blob/master/src/soter/soter_hash.h#L68
  38. ^ https://docs.cossacklabs.com/themis/architecture/soter/#data-integrity-and-authentication
  39. ^ https://github.com/cossacklabs/themis/blob/master/src/themis/secure_session_utils.c#L154
  40. ^ Bouncy Castle Технические характеристики, bouncycastle.org, получено 10 апреля 2018 г.
  41. ^ cryptlib набор средств шифрования, Питер Гутманн, дата обращения 28.11.2015
  42. ^ https://github.com/cossacklabs/themis#cryptosystems
  43. ^ https://docs.cossacklabs.com/themis/crypto-theory/cryptosystems/secure-cell/
  44. ^ https://github.com/cossacklabs/themis#cryptosystems
  45. ^ https://docs.cossacklabs.com/themis/crypto-theory/cryptosystems/secure-cell/
  46. ^ С Щиток, scute.org
  47. ^ а б С GnuPG's SCdaemon & gpg-agent, gnupg.org
  48. ^ а б С libp11 двигатель
  49. ^ hwfeatures.c, dev.gnupg.org
  50. ^ https://www.wolfssl.com/wolfSSL/Blog/Entries/2017/1/18_wolfSSL_Asynchronous_Intel_QuickAssist_Support.html
  51. ^ https://www.wolfssl.com/wolfSSL/Blog/Entries/2016/10/13_wolfSSL_ARMv8_Support.html
  52. ^ https://docs.cossacklabs.com/themis/crypto-theory/cryptography-donors/
  53. ^ а б Языковой анализ Botan, OpenHub.net, получено 18 июля 2018 г.
  54. ^ а б Языковой анализ надувного замка, OpenHub.net, получено 23 декабря 2015 г.
  55. ^ а б Языковой анализ Crypto ++, OpenHub.net, получено 18 июля 2018 г.
  56. ^ а б Языковой анализ Libgcrypt, OpenHub.net, получено 23 декабря 2015 г.
  57. ^ а б Языковой анализ libsodium, OpenHub.net, получено 07 мая 2017 г.
  58. ^ а б Языковой анализ крапивы, OpenHub.net, получено 23 декабря 2015 г.
  59. ^ а б Языковой анализ OpenSSL, OpenHub.net, получено 7 мая 2017 г.
  60. ^ а б Языковой анализ mbed-tls, OpenHub.net, получено 15 сентября 2019 г.
  61. ^ а б Языковой анализ Фемиды, OpenHub.net, получено 06.11.2020
  62. ^ Документация GnuPG: обзор Libgcrypt - безопасность потоков, GnuPG.org, получено 16 апреля 2016 г.
  63. ^ «Доступность ОС Фемиды». Github. Получено 2020-11-22.