Botan VS OpenSSL

Compare Botan vs OpenSSL and see what are their differences.

InfluxDB - Purpose built for real-time analytics at any scale.
InfluxDB Platform is powered by columnar analytics, optimized for cost-efficient storage, and built with open data standards.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
Botan OpenSSL
5 157
2,527 25,406
- 1.4%
9.9 9.9
4 days ago 2 days ago
C++ C
BSD 2-clause "Simplified" License Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

Botan

Posts with mentions or reviews of Botan. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-06-17.

OpenSSL

Posts with mentions or reviews of OpenSSL. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-09-12.
  • Better-performing "25519" elliptic-curve cryptography
    5 projects | news.ycombinator.com | 12 Sep 2024
    As an example, the Amazon implementation doesn't refer to gcc's[1] and clang's[2] "zero_call_used_regs" to zeroise CPU registers upon return or exception of functions working on crypto secrets. OpenSSL doesn't either.[3] firedancer _does_ use "zero_call_used_regs" to allow gcc/clang to zeroise used CPU registers.

    As another example, the Amazon implementation also doesn't refer to gcc's "strub" attribute which zeroises the function's stack upon return or exception of functions working on crypto secrets.[4][5] OpenSSL doesn't either.[3] firedancer _does_ use the "strub" attribute to allow gcc to zeroise the function's stack.

    Is there a performance impact? [6] has the overhead at 0% for X25519 for implementing CPU register and stack zeroisation. Compiling the Linux kernel with "CONFIG_ZERO_CALL_USED_REGS=1" for x64_64 (impacting all kernel functions) was found to result in a 1-1.5% performance penalty.[7][8]

    [1] https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attribute...

    [2] https://clang.llvm.org/docs/AttributeReference.html#zero-cal...

    [3] https://github.com/openssl/openssl/discussions/24321

    [4] https://gcc.gnu.org/onlinedocs/gcc-14.2.0/gcc/Common-Type-At...

    [5] https://gcc.gnu.org/onlinedocs/gcc/Stack-Scrubbing.html

    [6] https://eprint.iacr.org/2023/1713.pdf

    [7] https://www.phoronix.com/review/zero-used-regs/5

    [8] https://lore.kernel.org/lkml/20210505191804.4015873-1-keesco...

  • OpenSSL 3.3.2 Released
    2 projects | news.ycombinator.com | 3 Sep 2024
    you can check the CHANGES.md [1] or here [2]

    [1] https://github.com/openssl/openssl/blob/master/CHANGES.md

  • Kriptografi
    1 project | dev.to | 1 Aug 2024
  • OpenSSL New Governance Structure: A Call to the Academic Community
    1 project | news.ycombinator.com | 25 Jul 2024
  • Local Reverse Proxy
    3 projects | dev.to | 30 May 2024
    If you're going to use a custom local domain name, you might as well use a self-signed SSL certificate. I'll use OpenSSL for this:
  • How to Resolve Node.js ERR_OSSL_EVP_UNSUPPORTED Error
    1 project | dev.to | 28 May 2024
    Are you facing the notorious ERR_OSSL_EVP_UNSUPPORTED error in your Node.js applications? This error is a common stumbling block that occurs due to changes in cryptographic operations handling introduced with Node.js version 17. The root of the problem lies in the default configuration of OpenSSL in newer Node.js versions, which restricts the use of certain algorithms. Fortunately, there are effective solutions to overcome this error, ensuring your development process remains smooth and uninterrupted.
  • RVM Ruby 2.6.0 — built with custom openssl version on Ubuntu 22.04
    2 projects | dev.to | 26 Apr 2024
    ENV OPENSSL_PREFIX=/opt/openssl ENV SSL_CERT_FILE=/etc/ssl/certs/ca-certificates.crt WORKDIR /tmp RUN git clone --branch OpenSSL_1_0_2n https://github.com/openssl/openssl.git RUN cd openssl RUN ./config shared --prefix=$OPENSSL_PREFIX --openssldir=$OPENSSL_PREFIX/ssl RUN make RUN make install RUN rvm install 2.6.0 -C --with-openssl-dir=$OPENSSL_PREFIX ENV PATH /usr/local/rvm/bin:$PATH RUN rvm --default use ruby-2.6.0 ENV PATH /usr/local/rvm/bin:/usr/local/rvm/rubies/ruby-2.6.0/bin:$PATH ENV GEM_HOME /usr/local/rvm/rubies/ruby-2.6.0/lib/ruby/gems/2.6.0
  • Heartbleed and XZ Backdoor Learnings: Open Source Infrastructure Can Be Improved Efficiently With Moderate Funding
    2 projects | dev.to | 7 Apr 2024
    Today, April 7th, 2024, marks the 10-year anniversary since CVE-2014-0160 was published. This security vulnerability known as "Heartbleed" was a flaw in the OpenSSL cryptography software, the most popular option to implement Transport Layer Security (TLS). In more layman's terms, if you type https:// in your browser address bar, chances are high that you are interacting with OpenSSL.
  • Ask HN: How does the xz backdoor replace RSA_public_decrypt?
    1 project | news.ycombinator.com | 1 Apr 2024
    At this point I pretty much understand the entire process on how the xz backdoor came to be: its execution stages, extraction from binary "test" files etc. But one thing puzzles me: how can the ifunc mechanism be used to replace something like RSA_public_decrypt? Granted this probably stems from my lack of understanding of ifunc, but I was under the impression that in order for the ifunc mechanism to work in your code, you have to explicitly mark specific function with multiple implementations with __attribute__ ((ifunc ("the_resolver_function"))). Looking at the source code of the RSA function in question, ifunc attribute isn't present:

    https://github.com/openssl/openssl/blob/master/crypto/rsa/rsa_crpt.c#L51

    So how does the backdoor actually replace the call? Does this means that the ifunc mechanism can be used to override pretty much anything on the system?

  • Use of HTTPS Resource Records
    1 project | news.ycombinator.com | 4 Jan 2024
    OpenSSL and Go crypt/tls has no support yet, so none of the webservers that depend on them support it. Apache, Nginx, and Caddy, they all need upstream ECH support first.

    - https://github.com/openssl/openssl/issues/7482

    - https://github.com/openssl/openssl/pull/22938

    - https://github.com/golang/go/issues/63369

What are some alternatives?

When comparing Botan and OpenSSL you can also consider the following projects:

Crypto++ - free C++ class library of cryptographic schemes

GnuTLS - GnuTLS

libsodium - A modern, portable, easy to use crypto library.

mbedTLS - An open source, portable, easy to use, readable and flexible TLS library, and reference implementation of the PSA Cryptography API. Releases are on a varying cadence, typically around 3 - 6 months between releases.

LibreSSL - LibreSSL Portable itself. This includes the build scaffold and compatibility layer that builds portable LibreSSL from the OpenBSD source code. Pull requests or patches sent to [email protected] are welcome.

Tiny AES128 in C - Small portable AES128/192/256 in C

Themis - Easy to use cryptographic framework for data protection: secure messaging with forward secrecy and secure data storage. Has unified APIs across 14 platforms.

cfssl - CFSSL: Cloudflare's PKI and TLS toolkit

InfluxDB - Purpose built for real-time analytics at any scale.
InfluxDB Platform is powered by columnar analytics, optimized for cost-efficient storage, and built with open data standards.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured