#crypto #key #pkcs #private

no-std pkcs8

Pure Rust implementation of Public-Key Cryptography Standards (PKCS) #8: Private-Key Information Syntax Specification (RFC 5208), with additional support for PKCS#8v2 asymmetric key packages (RFC 5958)

29 releases

0.11.0-pre.0 Jan 8, 2024
0.10.2 Apr 5, 2023
0.10.1 Mar 5, 2023
0.9.0 May 8, 2022
0.0.0 Jun 12, 2020

#938 in Cryptography

Download history 555852/week @ 2023-10-29 597424/week @ 2023-11-05 673032/week @ 2023-11-12 570336/week @ 2023-11-19 610830/week @ 2023-11-26 646915/week @ 2023-12-03 594617/week @ 2023-12-10 532534/week @ 2023-12-17 299663/week @ 2023-12-24 481508/week @ 2023-12-31 618710/week @ 2024-01-07 647058/week @ 2024-01-14 677299/week @ 2024-01-21 694384/week @ 2024-01-28 648219/week @ 2024-02-04 605686/week @ 2024-02-11

2,661,969 downloads per month
Used in 2,173 crates (64 directly)

Apache-2.0 OR MIT


RustCrypto: PKCS#8 (Private Keys)

crate Docs Build Status Apache2/MIT licensed Rust Version Project Chat

Pure Rust implementation of Public-Key Cryptography Standards (PKCS) #8: Private-Key Information Syntax Specification (RFC 5208).


About PKCS#8

PKCS#8 is a format for cryptographic private keys, often containing pairs of private and public keys.

You can identify a PKCS#8 private key encoded as PEM (i.e. text) by the following:


PKCS#8 private keys can optionally be encrypted under a password using key derivation algorithms like PBKDF2 and scrypt, and encrypted with ciphers like AES-CBC. When a PKCS#8 private key has been encrypted, it starts with the following:


PKCS#8 private keys can also be serialized in an ASN.1-based binary format. The PEM text encoding is a Base64 representation of this format.

Supported Algorithms

This crate is implemented in an algorithm-agnostic manner with the goal of enabling PKCS#8 support for any algorithm.

That said, it has been tested for interoperability against keys generated by OpenSSL for the following algorithms:

  • ECC (id-ecPublicKey)
  • Ed25519 (id-Ed25519)
  • RSA (id-rsaEncryption)
  • X25519 (id-X25519)

Please open an issue if you encounter trouble using it with a particular algorithm, including the ones listed above or other algorithms.

Minimum Supported Rust Version

This crate requires Rust 1.71 at a minimum.

We may change the MSRV in the future, but it will be accompanied by a minor version bump.


Licensed under either of:

at your option.


Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.


~10K SLoC