概述
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;
}
}
最后
以上就是时尚玉米为你收集整理的PBKDF2的加密实例的全部内容,希望文章能够帮你解决PBKDF2的加密实例所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复