Java加密算法 PBE

下面是编程之家 jb51.cc 通过网络收集整理的代码片段。

编程之家小编现在分享给大家,也给大家做个参考。

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

以上是编程之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

相关文章

Java中的String是不可变对象 在面向对象及函数编程语言中,不...
String, StringBuffer 和 StringBuilder 可变性 String不可变...
序列化:把对象转换为字节序列的过程称为对象的序列化. 反序...
先说结论,是对象!可以继续往下看 数组是不是对象 什么是对...
为什么浮点数 float 或 double 运算的时候会有精度丢失的风险...
面试题引入 这里引申出一个经典问题,看下面代码 Integer a ...