- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
javaêμ??RSA?ó?ü
á÷3ì·???£o
1?¢?×·?11?¨?ü?????ù£???1???1?2???òò·?£???????±£á??£
2?¢?×·?ê1ó??????ó?üêy?Y£?è?oóó????????ó?üoóμ?êy?Y????£?·¢?í??òò·?????ò??°?ó?üoóμ?êy?Y£?òò·?ê1ó?1????¢????à′?é?¤′y?a?üêy?Yê?·?óDD§£?è?1?óDD§ê1ó?1?????êy?Y?a?ü?£
3?¢òò·?ê1ó?1????ó?üêy?Y£??ò?×·?·¢?í?-1y?ó?üoóμ?êy?Y£??×·???μ??ó?üêy?Y£?í¨1y?????a?ü?£
í¨1yjava′ú??êμ??è???£o
import java.security.Key;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.Signature;
import erfaces.RSAPrivateKey;
import erfaces.RSAPublicKey;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;
import java.util.HashMap;
import java.util.Map;
import javax.crypto.Cipher;
/** *//**
* RSA°2è?±à??×é?t
*
* @version 1.0
* @since 1.0
*/
public abstract class RSACoder extends Coder {
public static final String KEY_ALGORITHM = RSA;
public static final String SIGNATURE_ALGORITHM = MD5withRSA;
private static final String PUBLIC_KEY = RSAPublicKey;
private static final String PRIVATE_KEY = RSAPrivateKey;
/** *//**
* ó???????D??¢éú3éêy×?????
*
* @param data
* ?ó?üêy?Y
* @param privateKey
* ????
*
* @return
* @throws Exception
*/
public static String sign(byte[] data, String privateKey) throws Exception {
// ?a?üóébase64±à??μ?????
byte[] keyBytes = decryptBASE64(privateKey);
// 11?ìPKCS8EncodedKeySpec???ó
PKCS8EncodedKeySpec pkcs8KeySpec = new PKCS8EncodedKeySpec(keyBytes);
// KEY_ALGORITHM ???¨μ??ó?ü??·¨
KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORITHM);
// è?????3×???ó
PrivateKey priKey = keyFactory.generatePrivate(pkcs8KeySpec);
// ó???????D??¢éú3éêy×????
文档评论(0)