SM9 (cryptography standard)


SM9 is a Chinese national cryptography standard for Identity Based Cryptography issued by the Chinese State Cryptographic Authority in March 2016.  It is represented by the Chinese National Cryptography Standard, GM/T 0044-2016 SM9. The standard contains the following components:
is a type of public key cryptography that uses a widely known representation of an entity's Identity as the entities public key. This eliminates the need to have a separate public key bound by some mechanism to the Identity of an entity. In Identity Based Cryptography the public key is often taken as the concatenation of an entity's Identity and a validity period for the public key.
In Identity Based Cryptography, one or more trusted agent's use their private keys to compute an entity's private key from their public key. The corresponding public keys of the trusted agent or agents are known to everyone using the network. If only one trusted agent is used that trusted agent can compute all the private keys for users in the network. To avoid that state, some researchers propose using multiple trusted agents in such a way that more than one of them need to be compromised in order to compute individual public keys.

Chinese Cryptographic Standards

The SM9 Standard adopted in 2016 is one of a number of Chinese national cryptography standards. Other publicly available Chinese cryptographic standards are:
The SM9 standard along with these other standards are issued by the Chinese State Cryptographic Authority. The first part of the standard SM9-1 provides and overview of the standard.

SM9 Identity Based Signature Algorithm

The Identity Based Signature Algorithm in SM9 traces its origins to an Identity Based Signature Algorithm published at Asiacrypt 2005 in the paper: "Efficient and Provably-Secure Identity-Based Signatures and Signcryption from Bilinear Maps" by Barreto, Libert, McCullagh, and Quisquater. It was standardized in IEEE 1363.3 and in ISO/IEC 14888-3:2015.

SM9 Identity Based Key Encapsulation

The Identity Based Key Encapsulation Algorithm in SM9 traces its origins to a 2003 paper by Sakai and Kasahara titled "." It was standardized in IEEE 1363.3, in ISO/IEC 18033-5:2015 and IETF RFC 6508.

SM9 Identity Based Key Agreement

The Identity Based Key Agreement algorithm in SM9 traces its origins to a 2004 paper by McCullagh and Barreto titled, "A New Two-Party Identity-Based Authenticated Key Agreement" . The International Standards Organization incorporated this identity key exchange protocol algorithm into ISO/IEC 11770-3 in 2015.

Implementations of SM9

An open source implementation of the SM9 algorithms is part of the package available on Github. The Shenzhen Aolian Information Security Technology Co is also marketing a series of products that implement the SM9 algorithms.

Further Information

The following links provide more detailed information on the SM9 algorithms in English: