Java加密算法 PBE
发布时间:2020-12-14 23:26:13 所属栏目:Java 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 import java.util.Arrays; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypt
以下代码由PHP站长网 52php.cn收集自互联网 现在PHP站长网小编把它分享给大家,仅供参考 import java.util.Arrays; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.PBEKeySpec; import javax.crypto.spec.PBEParameterSpec; /** * PBE算法 对称加密 password-based encryption * @author stone * @date 2014-03-10 23:41:35 */ public class PBE { static final String KEY_ALGORITHM = "PBEWithMD5AndDES"; // static byte[] salt = "xiaoyang".getBytes(); // 盐:Salt must be 8 bytes long static byte[] salt = "哈皮aa".getBytes(); // 盐:Salt must be 8 bytes long 哈皮,在utf8中是6个字节 static int iterationCount = 888; //循环次数 static Cipher cipher; public static void main(String[] args) throws Exception { byte[] encrypt = encrypt("中华人民admin*&(*S&6"); System.out.println("PBE加密后:" + Arrays.toString(encrypt)); System.out.println("PBE解密后:" + decrypt(encrypt)); } /** * 使用PBE 算法 加密 * @return 加密后的字符数组 * @throws Exception */ static byte[] encrypt(String str) throws Exception { cipher = Cipher.getInstance(KEY_ALGORITHM); //使用SecretKeyFactory 生成key SecretKeyFactory factory = SecretKeyFactory.getInstance(KEY_ALGORITHM); PBEKeySpec keySpec = new PBEKeySpec("shizongyin".toCharArray()); SecretKey key = factory.generateSecret(keySpec); System.out.println("key:" + Arrays.toString(key.getEncoded())); cipher.init(Cipher.ENCRYPT_MODE,key,new PBEParameterSpec(salt,iterationCount));//使用加密模式初始化 密钥 return cipher.doFinal(str.getBytes()); //按单部分操作加密或解密数据,或者结束一个多部分操作。 } /** * * @param encrypt * @return * @throws Exception */ static String decrypt(byte[] encrypt) throws Exception { cipher = Cipher.getInstance(KEY_ALGORITHM); //使用SecretKeyFactory 生成key SecretKeyFactory factory = SecretKeyFactory.getInstance(KEY_ALGORITHM); PBEKeySpec keySpec = new PBEKeySpec("shizongyin".toCharArray()); SecretKey key = factory.generateSecret(keySpec); System.out.println("key:" + Arrays.toString(key.getEncoded())); cipher.init(Cipher.DECRYPT_MODE,iterationCount));//使用加密模式初始化 密钥 byte[] result = cipher.doFinal(encrypt); //按单部分操作加密或解密数据,或者结束一个多部分操作。 return new String(result); } } 以上内容由PHP站长网【52php.cn】收集整理供大家参考研究 如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |