JavaAES256加密解密代码怎么写呢

这篇文章将为大家详细讲解有关JavaAES256加密解密代码怎么写呢,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

目前成都创新互联公司已为上千多家的企业提供了网站建设、域名、虚拟主机网站托管运营、企业网站设计、浙江网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

Java支持许多安全的加密算法,但是其中一些功能较弱,无法在安全性要求很高的应用程序中使用。例如,数据加密标准(DES)加密算法被认为是高度不安全的。今天介绍一下AES 256加密解密。

什么是AES 256?

高级加密标准 (英语:Advanced Encryption Standard,缩写:AES ),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。  AES是一种对称加密算法。它旨在易于在硬件和软件以及受限环境中实施,并提供针对各种攻击技术的良好防御。AES是能够使用大小为128、192和256位的密钥处理128位块的块密码。每个密码分别使用128位,192位和256位的加密密钥对128位块中的数据进行加密和解密。它使用相同的密钥进行加密和解密,因此发送方和接收方都必须知道并使用相同的秘密密钥。

在下面的加密和解密示例中,我在UTF-8字符集中使用了base64编码。用于显示程序的输出。也可以以字节数组格式存储和验证数据。

AES 256加密

Java程序中,用于使用AES 256位对密码(或任何信息)进行加密。

private static String secretKey = "boooooooooom!!!!";private static String salt = "ssshhhhhhhhhhh!!!!"; public static String encrypt(String strToEncrypt, String secret){  try  {    byte[] iv = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };    IvParameterSpec ivspec = new IvParameterSpec(iv);         SecretKeyFactory factory = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA256");    KeySpec spec = new PBEKeySpec(secretKey.toCharArray(), salt.getBytes(), 65536, 256);    SecretKey tmp = factory.generateSecret(spec);    SecretKeySpec secretKey = new SecretKeySpec(tmp.getEncoded(), "AES");         Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");    cipher.init(Cipher.ENCRYPT_MODE, secretKey, ivspec);    return Base64.getEncoder().encodeToString(cipher.doFinal(strToEncrypt.getBytes("UTF-8")));  }  catch (Exception e)  {    System.out.println("Error while encrypting: " + e.toString());  }  return null;}

AES 256解密

Java程序,用于使用AES 256位解密密码(或任何信息)。

private static String secretKey = "boooooooooom!!!!";private static String salt = "ssshhhhhhhhhhh!!!!"; public static String decrypt(String strToDecrypt, String secret) {  try  {    byte[] iv = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };    IvParameterSpec ivspec = new IvParameterSpec(iv);         SecretKeyFactory factory = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA256");    KeySpec spec = new PBEKeySpec(secretKey.toCharArray(), salt.getBytes(), 65536, 256);    SecretKey tmp = factory.generateSecret(spec);    SecretKeySpec secretKey = new SecretKeySpec(tmp.getEncoded(), "AES");         Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");    cipher.init(Cipher.DECRYPT_MODE, secretKey, ivspec);    return new String(cipher.doFinal(Base64.getDecoder().decode(strToDecrypt)));  }  catch (Exception e) {    System.out.println("Error while decrypting: " + e.toString());  }  return null;}

测试AES256加密和解密方法

用一个简单的字符串测试我们的AES256加密和解密方法

public static void main(String[] args){  String originalString = "www.csdn.net";     String encryptedString = AES.encrypt(originalString, secretKey) ;  String decryptedString = AES.decrypt(encryptedString, secretKey) ;     System.out.println(originalString);  System.out.println(encryptedString);  System.out.println(decryptedString);}

输出结果

www.csdn.netbiXhp3Ha1fgxVEp48zHrvVoXMStmxPuAPHo3TVz5lHU=www.csdn.net

关于JavaAES256加密解密代码怎么写呢就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


分享标题:JavaAES256加密解密代码怎么写呢
文章URL:http://cdiso.cn/article/jphejg.html

其他资讯