Unicode C
Unicode C
Load RSA Public Key from JWK Format (JSON Web Key)
See more RSA Examples
Demonstrates how to load an RSA public key from JWK (JSON Web Key) format.Note: This example requires Chilkat v9.5.0.66 or later.
Chilkat Unicode C Downloads
#include <C_CkJsonObjectW.h>
#include <C_CkPublicKeyW.h>
void ChilkatSample(void)
{
BOOL success;
HCkJsonObjectW json;
const wchar_t *jwkStr;
HCkPublicKeyW pubKey;
BOOL bPreferPkcs1;
success = FALSE;
// Note: This example requires Chilkat v9.5.0.66 or later.
// First build a JWK sample to load..
json = CkJsonObjectW_Create();
CkJsonObjectW_UpdateString(json,L"kty",L"RSA");
CkJsonObjectW_UpdateString(json,L"n",L"33TqqLR3eeUmDtHS89qF3p4MP7Wfqt2Zjj3lZjLjjCGDvwr9cJNlNDiuKboODgUiT4ZdPWbOiMAfDcDzlOxA04DDnEFGAf-kDQiNSe2ZtqC7bnIc8-KSG_qOGQIVaay4Ucr6ovDkykO5Hxn7OU7sJp9TP9H0JH8zMQA6YzijYH9LsupTerrY3U6zyihVEDXXOv08vBHk50BMFJbE9iwFwnxCsU5-UZUZYw87Uu0n4LPFS9BT8tUIvAfnRXIEWCha3KbFWmdZQZlyrFw0buUEf0YN3_Q0auBkdbDR_ES2PbgKTJdkjc_rEeM0TxvOUf7HuUNOhrtAVEN1D5uuxE1WSw");
CkJsonObjectW_UpdateString(json,L"e",L"AQAB");
// The JSON contains the following:
// {
// "kty": "RSA",
// "n": "33TqqLR3eeUmDtHS89qF3p4MP7Wfqt2Zjj3lZjLjjCGDvwr9cJNlNDiuKboODgUiT4ZdPWbOiMAfDcDzlOxA04DDnEFGAf-kDQiNSe2ZtqC7bnIc8-KSG_qOGQIVaay4Ucr6ovDkykO5Hxn7OU7sJp9TP9H0JH8zMQA6YzijYH9LsupTerrY3U6zyihVEDXXOv08vBHk50BMFJbE9iwFwnxCsU5-UZUZYw87Uu0n4LPFS9BT8tUIvAfnRXIEWCha3KbFWmdZQZlyrFw0buUEf0YN3_Q0auBkdbDR_ES2PbgKTJdkjc_rEeM0TxvOUf7HuUNOhrtAVEN1D5uuxE1WSw",
// "e": "AQAB",
// }
// Note: The JSON can contain other members, such as "use", "kid", or anything else. These will be ignored.
CkJsonObjectW_putEmitCompact(json,FALSE);
// Show the JWK string to be loaded:
jwkStr = CkJsonObjectW_emit(json);
pubKey = CkPublicKeyW_Create();
// The LoadFromString method will automatically detect the format.
success = CkPublicKeyW_LoadFromString(pubKey,jwkStr);
if (success != TRUE) {
wprintf(L"%s\n",CkPublicKeyW_lastErrorText(pubKey));
CkJsonObjectW_Dispose(json);
CkPublicKeyW_Dispose(pubKey);
return;
}
// OK.. the JWK is loaded. It can be used in whatever way desired...
// The key can be retrieved in any other format, such as XML or PEM..
wprintf(L"%s\n",CkPublicKeyW_getXml(pubKey));
// XML output:
// <RSAPublicKey>
// <Modulus>33TqqLR3eeUmDtHS89qF3p4MP7Wfqt2Zjj3lZjLjjCGDvwr9cJNlNDiuKboODgUiT4ZdPWbOiMAfDcDzlOxA04DDnEFGAf+kDQiNSe2ZtqC7bnIc8+KSG/qOGQIVaay4Ucr6ovDkykO5Hxn7OU7sJp9TP9H0JH8zMQA6YzijYH9LsupTerrY3U6zyihVEDXXOv08vBHk50BMFJbE9iwFwnxCsU5+UZUZYw87Uu0n4LPFS9BT8tUIvAfnRXIEWCha3KbFWmdZQZlyrFw0buUEf0YN3/Q0auBkdbDR/ES2PbgKTJdkjc/rEeM0TxvOUf7HuUNOhrtAVEN1D5uuxE1WSw==</Modulus>
// <Exponent>AQAB</Exponent>
// </RSAPublicKey>
// Choose PCKS1 or PCKS8 PEM format..
bPreferPkcs1 = FALSE;
wprintf(L"%s\n",CkPublicKeyW_getPem(pubKey,bPreferPkcs1));
// PEM output
// -----BEGIN PUBLIC KEY-----
// MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA33TqqLR3eeUmDtHS89qF
// 3p4MP7Wfqt2Zjj3lZjLjjCGDvwr9cJNlNDiuKboODgUiT4ZdPWbOiMAfDcDzlOxA
// 04DDnEFGAf+kDQiNSe2ZtqC7bnIc8+KSG/qOGQIVaay4Ucr6ovDkykO5Hxn7OU7s
// Jp9TP9H0JH8zMQA6YzijYH9LsupTerrY3U6zyihVEDXXOv08vBHk50BMFJbE9iwF
// wnxCsU5+UZUZYw87Uu0n4LPFS9BT8tUIvAfnRXIEWCha3KbFWmdZQZlyrFw0buUE
// f0YN3/Q0auBkdbDR/ES2PbgKTJdkjc/rEeM0TxvOUf7HuUNOhrtAVEN1D5uuxE1W
// SwIDAQAB
// -----END PUBLIC KEY-----
CkJsonObjectW_Dispose(json);
CkPublicKeyW_Dispose(pubKey);
}