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; }