Swift
Swift
Create a JWS Using ECDSA P-521 SHA-512
See more JSON Web Signatures (JWS) Examples
Creates and verifies a JSON Web Signature (JWS) that uses ECDSA P-521 SHA-512Chilkat Swift Downloads
func chilkatTest() {
var success: Bool = false
// This requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// Note: This example requires Chilkat v9.5.0.66 or greater.
// Use the following ECC key loaded from JWK format.
let sbJwk = CkoStringBuilder()!
sbJwk.append(value: "{\"kty\":\"EC\",")
sbJwk.append(value: "\"crv\":\"P-521\",")
sbJwk.append(value: "\"x\":\"AekpBQ8ST8a8VcfVOTNl353vSrDCLLJXmPk06wTjxrrjcBpXp5EOnYG_NjFZ6OvLFV1jSfS9tsz4qUxcWceqwQGk\",")
sbJwk.append(value: "\"y\":\"ADSmRA43Z1DSNx_RvcLI87cdL07l6jQyyBXMoxVg_l2Th-x3S1WDhjDly79ajL4Kkd0AZMaZmh9ubmf63e3kyMj2\",")
sbJwk.append(value: "\"d\":\"AY5pb7A0UFiB3RELSD64fTLOSV_jazdF7fLYyuTw8lOfRhWg6Y6rUrPAxerEzgdRhajnu0ferB0d53vM9mE15j2C\"")
sbJwk.append(value: "}")
let eccKey = CkoPrivateKey()!
// Note: This example loads the ECDSA key from JWK format. Any format can be loaded
// into the private key object. (See the online reference documentation..)
success = eccKey.loadJwk(jsonStr: sbJwk.getAsString())
if success == false {
print("\(eccKey.lastErrorText!)")
return
}
// Create the JWS Protected Header
let jwsProtHdr = CkoJsonObject()!
jwsProtHdr.appendString(name: "alg", value: "ES512")
let jws = CkoJws()!
// Set the protected header:
var signatureIndex: Int = 0
jws.setProtectedHeader(index: signatureIndex, json: jwsProtHdr)
// Set the ECC key:
jws.setPrivateKey(index: signatureIndex, privKey: eccKey)
// Set the payload.
var bIncludeBom: Bool = false
var payloadStr: String? = "In our village, folks say God crumbles up the old moon into stars."
jws.setPayload(payload: payloadStr, charset: "utf-8", includeBom: bIncludeBom)
// Create the JWS
// By default, the compact serialization is used.
var jwsCompact: String? = jws.create()
if jws.lastMethodSuccess == false {
print("\(jws.lastErrorText!)")
return
}
print("JWS: \(jwsCompact!)")
// Note: ECC signatures use random values, so the output will be different each time a signature is produced.
// sample output:
// JWS: eyJhbGciOiJFUzUxMiJ9.SW4gb3VyIHZpbGxhZ2UsIGZvbGtzIHNheSBHb2QgY3J1bWJsZXMgdXAgdGhlIG9sZCBtb29uIGludG8gc3RhcnMu.AFOnOtZ8UTp-ed1PfLfXxwGU7zT_jnmGGxew-d1CP6SfKa5RUhav5mF4szhSof22JaoQ742VIa0eZ0s1rhBnj8y6APr6g6vKzIpYZlJsnjzjUwAjDQOLmcsjxrrRfATh-NEv7G0Z9FrjdJasS44tCG2EnG6aT2TW-sPG0dy5o9jUWCzi
// Now load the JWS, validate, and recover the original text.
let jws2 = CkoJws()!
// Load the JWS.
success = jws2.load(jwsStr: jwsCompact)
let eccPubKey = CkoPublicKey()!
eccKey.toPublicKey(pubKey: eccPubKey)
// Set the ECC public key used for validation.
signatureIndex = 0
jws2.setPublicKey(index: signatureIndex, pubKey: eccPubKey)
// Validate the 1st (and only) signature at index 0..
var v: Int = jws2.validate(index: signatureIndex).intValue
if v < 0 {
// Perhaps Chilkat was not unlocked or the trial expired..
print("Method call failed for some other reason.")
print("\(jws2.lastErrorText!)")
return
}
if v == 0 {
print("Invalid signature. The ECC key was incorrect, the JWS was invalid, or both.")
return
}
// If we get here, the signature was validated..
print("Signature validated.")
// Recover the original content:
print("\(jws2.getPayload(charset: "utf-8")!)")
// Examine the protected header:
let joseHeader = CkoJsonObject()!
jws2.getProtectedH(index: signatureIndex, json: joseHeader)
joseHeader.emitCompact = false
print("Protected (JOSE) header:")
print("\(joseHeader.emit()!)")
// Output:
// Signature validated.
// In our village, folks say God crumbles up the old moon into stars.
// Protected (JOSE) header:
// {
// "alg": "ES512"
// }
}