api 公钥私钥的一点看法
来源:互联网 发布:淘宝电视机价格 编辑:程序博客网 时间:2024/06/05 11:56
des + md5 + key
公钥和私钥是配对存在,相互可解密对方加密数据。私钥一般是服务提供方保存,而公钥则提供给服务使用者。
提供https服务,则服务访问者,第一次需要下载公钥,而私钥则保存在服务提供方。
简单代码
/** * RSA数据加密 * @param keyValue 公钥/私钥的值 * @param plainText 待加密数据 * @param keyType 秘钥类型 @RSAKeyType * @return */ public static byte[] RSAEncode(String keyValue, byte[] plainText, RSAKeyType keyType) throws Exception { Key key = getKey(keyValue, keyType); try { Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); cipher.init(Cipher.ENCRYPT_MODE, key); return cipher.doFinal(plainText); } catch (Exception e) { log.debug("RSAEncode error. [error={}] [keyValue={}] [plainText={}] [keyType={}]", e.getMessage(),keyValue, plainText, keyType); } return null; }
/** * 解密 * @param keyValue 公钥/私钥的值 * @param plainText 待解密数据 * @param keyType 秘钥类型 @RSAKeyType * @return */ public static String RSADecode(String keyValue, byte[] encodedText, RSAKeyType keyType) throws Exception { Key key = getKey(keyValue, keyType); try { Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); cipher.init(Cipher.DECRYPT_MODE, key); return new String(cipher.doFinal(encodedText)); } catch (Exception e) { log.debug("RSAEncode error. [error={}] [keyValue={}] [encodedText={}] [keyType={}]", e.getMessage(),keyValue, encodedText, keyType); } return null; } private static Key getKey(String keyStr, RSAKeyType keyType) throws Exception{ Key key = null; if(RSAKeyType.PRIVATE.name().equals(keyType.name())){ key = restorePrivateKey(decryptBASE64(keyStr)); }else if(RSAKeyType.PUBLIC.name().equals(keyType.name())){ key = restorePublicKey(decryptBASE64(keyStr)); } return key; }
0 0
- api 公钥私钥的一点看法
- cout<<的一点看法
- GUI的一点看法
- 对SharePoint的一点看法
- 有关Iterator的一点看法
- 有关JMS的一点看法
- 关于linb的一点看法
- 关于跳槽的一点看法
- 对需求的一点看法
- 关于新技术的一点看法
- java 学习的一点看法
- 高效会议的一点看法
- 一点关于Ares的看法
- 关于Velocity的一点看法
- 初学c#的一点看法
- 设计模式的一点看法
- 关于积累的一点看法
- 关于积累的一点看法
- 水仙花树;
- 前端-CSS基础知识(二)
- Redis 学习笔记(十一)基数统计(HyperLogLog)
- Linux基础备忘_08: LTP(Linux test project)
- DirectX 配置 vs2013 Win10 64bit
- api 公钥私钥的一点看法
- ViewPager的PagerAdapter的封装
- 现代企业该清楚的商业智能分析解决方案
- 指针和数组名及字符串的区别
- 面试机试之奖励问题
- kali渗透metasploitable靶机
- 使用matlab对训练样本图像降维,并对测试图像使用变换矩阵降维并重构
- MTK SmartPhone Record-(1)
- swift修改UITextfield的Placeholder字体大小和颜色