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);
///