bp14
bp14

Reputation: 244

Encode publicKey on Java Card

How to encode an ECDSA PublicKey on Java Card so that after I can decode it on another platform (e.g. sending the encoded key in a response APDU and processing it in a standard Java application)? keyPair.getPublic().getEncoded() on Java would do the trick with PKCS#8 encoding, but as far as I know getEncoded() is not available on the Java Card platform.

Upvotes: 2

Views: 580

Answers (2)

unknwyshsa
unknwyshsa

Reputation: 91

You can implement this function like this:

Card side:

  • 1 KeyPair.getPublicKey() --> publicKey;
  • 2 publicKey.getW() --> W;
  • 3 Send W to outside;

Standard java application side:

  • 1 get W data bytes;
  • 2 W data bytes --> ECPoint;
  • 3 Build PublicKey with the ECPoint generated in step 2 use the class ECPublicKeySpec;
  • 4 Use the public key in your application;

Upvotes: 4

Ebrahim Ghasemi
Ebrahim Ghasemi

Reputation: 6116

getEncoded() method returns the key in its primary encoding format, or null if the key does not support encoding. So you don't need to use it for your goal. you simply can use down-casting to ECPublicKey:

ECPublicKey pubKey = (ECPublicKey) keyPair.getPublic()

The pubKey in the above line, is equal with output of getEncoded() method in Java applications.

Upvotes: 1

Related Questions