static boolean validate(License license1)
throws Exception
{
//生成公钥
String s = "308201b......d06d854a";
byte abyte0[] = StringUtils.decodeHex(s);
X509EncodedKeySpec x509encodedkeyspec = new X509EncodedKeySpec(abyte0);
KeyFactory keyfactory = KeyFactory.getInstance("DSA");
java.security.PublicKey publickey = keyfactory.generatePublic(x509encodedkeyspec);
Signature signature = Signature.getInstance("DSA");
signature.initVerify(publickey);
//更新指纹,也就是License中的所有内容(除了最后的signature)。
signature.update(license1.getFingerprint());
//进行校验,如果内容被改动,则返回false;
return signature.verify(StringUtils.decodeHex(license1.getSignature()));
}
X509EncodedKeySpec keySpec=new X509EncodedKeySpec(publicKeyBytes);
KeyFactory keyFactory=KeyFactory.getInstance("RSA");
PublicKey publickey=keyFactory.generatePublic(keySpec);
//////////////////////////////////////////////
KeyPair kp = KeyPairGenerator.getInstance("RSA").generateKeyPair();
PublicKey pubk = kp.getPublic();
byte[] encodedata = pubk.getEncoded();
// 將 encodedata 傳至遠端…
X509EncodedKeySpec keySpec = new X509EncodedKeySpec(encodedata);
KeyFactory keyFactory = KeyFactory.getInstance("RSA");
PublicKey publicKey = keyFactory.generatePublic(keySpec);
///////////////////////////////////////////////////

博客给出了Java代码示例,包含validate方法用于生成公钥并对License进行校验,若内容改动则返回false。还展示了使用RSA算法生成公钥、获取编码数据,以及在远端根据编码数据重新生成公钥的代码。

被折叠的 条评论
为什么被折叠?



