PBKDF2的加密实例

package demo;


import java.security.NoSuchAlgorithmException;
import java.security.spec.InvalidKeySpecException;


import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.PBEKeySpec;


public class Demo {


public static void main(String[] args) throws Exception 

{

byte[] bytes=hashPassword("PBKDF2WithHmacSHA1","123456","abcdefg",1024,128);
for(byte b:bytes)
{
System.out.println(b);
}

}








    public static byte[] hashPassword(String algorithm, String password, 
    String salt, int iterations, int len) throws Exception
    {
   
    //带有生成可变密钥大小的 PBE 密码的 PBEKey 时使用的一个密码、salt、迭代计数以及导出密钥长度的构造方法
       PBEKeySpec pbeKeySpec = new PBEKeySpec(password.toCharArray(), 
        salt.getBytes(), iterations, len);
       //返回转换指定算法的密钥的secretKeyFactory 对象
       SecretKeyFactory kFactory=SecretKeyFactory.getInstance(algorithm);
       //根据提供的密钥规范(材料)生成secretKey接口
       SecretKey secretKey = kFactory.generateSecret(pbeKeySpec);
       //返回基本编码格式的密钥  如果此密钥不支持编码,则返回 null
       byte[] buff = secretKey.getEncoded();
       return buff;
}

   
}

你可能感兴趣的:(加密算法)