Sample code for 30+ languages & platforms
PureBasic

Load ECC Public Key from JWK Format (JSON Web Key)

See more ECC Examples

Demonstrates how to load an ECC public key from JWK (JSON Web Key) format.

Note: This example requires Chilkat v9.5.0.66 or later.

Chilkat PureBasic Downloads

PureBasic
IncludeFile "CkPublicKey.pb"
IncludeFile "CkJsonObject.pb"

Procedure ChilkatExample()

    success.i = 0

    ; Note: This example requires Chilkat v9.5.0.66 or later.

    ; First build a JWK sample to load..
    json.i = CkJsonObject::ckCreate()
    If json.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    CkJsonObject::ckUpdateString(json,"kty","EC")
    CkJsonObject::ckUpdateString(json,"crv","P-256")
    CkJsonObject::ckUpdateString(json,"x","oBUyo8CQAFPeYPvv78ylh5MwFZjTCLQeb042TjiMJxE")
    CkJsonObject::ckUpdateString(json,"y","vvQyxZkUjJQUPU_0bCy3Pj5qQdfu8jwEfqEeYGZ95CU")

    ; The JSON contains the following:
    ; { 
    ;   "kty": "EC",
    ;   "crv": "P-256",
    ;   "x": "oBUyo8CQAFPeYPvv78ylh5MwFZjTCLQeb042TjiMJxE",
    ;   "y": "vvQyxZkUjJQUPU_0bCy3Pj5qQdfu8jwEfqEeYGZ95CU",
    ; }

    ; Note: The JSON can contain other members, such as "use", "kid", or anything else.  These will be ignored.
    CkJsonObject::setCkEmitCompact(json, 0)

    ; Show the JWK string to be loaded:
    jwkStr.s = CkJsonObject::ckEmit(json)

    pubKey.i = CkPublicKey::ckCreate()
    If pubKey.i = 0
        Debug "Failed to create object."
        ProcedureReturn
    EndIf

    ; The LoadFromString method will automatically detect the format.
    success = CkPublicKey::ckLoadFromString(pubKey,jwkStr)
    If success <> 1
        Debug CkPublicKey::ckLastErrorText(pubKey)
        CkJsonObject::ckDispose(json)
        CkPublicKey::ckDispose(pubKey)
        ProcedureReturn
    EndIf

    ; 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..
    Debug CkPublicKey::ckGetXml(pubKey)

    ; XML output:
    ; <ECCPublicKey curve="secp256r1" 
    ;    x="A01532A3C0900053DE60FBEFEFCCA58793301598D308B41E6F4E364E388C2711" 
    ;    y="BEF432C599148C94143D4FF46C2CB73E3E6A41D7EEF23C047EA11E60667DE425">
    ;    MIIBSzCCAQMGByqGSM49AgEwgfcCAQEwLAYHKoZIzj0BAQIhAP////8AAAABAAAAAAAAAAAAAAAA////////////////MFsEIP////8AAAABAAAAAAAAAAAAAAAA///////////////8BCBaxjXYqjqT57PrvVV2mIa8ZR0GsMxTsPY7zjw+J9JgSwMVAMSdNgiG5wSTamZ44ROdJreBn36QBEEEaxfR8uEsQkf4vOblY6RA8ncDfYEt6zOg9KE5RdiYwpZP40Li/hp/m47n60p8D54WK84zV2sxXs7LtkBoN79R9QIhAP////8AAAAA//////////+85vqtpxeehPO5ysL8YyVRAgEBA0IABKAVMqPAkABT3mD77+/MpYeTMBWY0wi0Hm9ONk44jCcRvvQyxZkUjJQUPU/0bCy3Pj5qQdfu8jwEfqEeYGZ95CU=
    ; </ECCPublicKey>

    ; Choose PCKS1 or PCKS8 PEM format..
    bPreferPkcs1.i = 0
    Debug CkPublicKey::ckGetPem(pubKey,bPreferPkcs1)

    ; PEM output
    ; -----BEGIN PUBLIC KEY-----
    ; MIIBSzCCAQMGByqGSM49AgEwgfcCAQEwLAYHKoZIzj0BAQIhAP////8AAAABAAAA
    ; AAAAAAAAAAAA////////////////MFsEIP////8AAAABAAAAAAAAAAAAAAAA////
    ; ///////////8BCBaxjXYqjqT57PrvVV2mIa8ZR0GsMxTsPY7zjw+J9JgSwMVAMSd
    ; NgiG5wSTamZ44ROdJreBn36QBEEEaxfR8uEsQkf4vOblY6RA8ncDfYEt6zOg9KE5
    ; RdiYwpZP40Li/hp/m47n60p8D54WK84zV2sxXs7LtkBoN79R9QIhAP////8AAAAA
    ; //////////+85vqtpxeehPO5ysL8YyVRAgEBA0IABKAVMqPAkABT3mD77+/MpYeT
    ; MBWY0wi0Hm9ONk44jCcRvvQyxZkUjJQUPU/0bCy3Pj5qQdfu8jwEfqEeYGZ95CU=
    ; -----END PUBLIC KEY-----


    CkJsonObject::ckDispose(json)
    CkPublicKey::ckDispose(pubKey)


    ProcedureReturn
EndProcedure