Reconstruct RSA public key from exponent and modulus

(1) Convert exponent and modulus to hex if they are not.

echo -n BASE64_VALUE|base64 --decode | xxd -p -u | tr -d \\n

(2) Create an asn1 definition file, replace the yellow color value with the value obtained in step (1).

# Start with a SEQUENCE
asn1=SEQUENCE:pubkeyinfo

# pubkeyinfo contains an algorithm identifier and the public key wrapped
# in a BIT STRING
[pubkeyinfo]
algorithm=SEQUENCE:rsa_alg
pubkey=BITWRAP,SEQUENCE:rsapubkey

# algorithm ID for RSA is just an OID and a NULL
[rsa_alg]
algorithm=OID:rsaEncryption
parameter=NULL

# Actual public key: modulus and exponent
[rsapubkey]
n=INTEGER:0xHEX_MODULUS_VALUE

e=INTEGER:0xHEX_EXPONENT_VALUE

(3) Save the file as "def.asn1".

(4) Use OpenSSL to construct DER from ASN1.

openssl asn1parse -genconf def.asn1 -out pubkey.der -noout

(5) Use OpenSSL to convert DER to PEM format.

openssl rsa -in pubkey.der -inform der -pubin -out pubkey.pem

(6) Obtain the Public Key in PEM file.

cat pubkey.pem

AI Summary
Chrome On-device AI 2024-09-19 19:36:31

Share Article