【java】aes,salt

AES(高級加密標準)是一種對稱加密算法,廣泛用于數據加密。在使用 AES 加密時,通常會結合鹽值(Salt)來增強安全性。鹽值是一個隨機生成的值,用于防止彩虹表攻擊和提高加密的復雜性。

一、AES 加密的基本概念

AES 是一種對稱加密算法,使用相同的密鑰進行加密和解密。AES 支持多種密鑰長度,如 128 位、192 位和 256 位。在實際應用中,通常使用 128 位密鑰,因為它在安全性和性能之間取得了較好的平衡。

二、鹽值(Salt)的作用

鹽值是一個隨機生成的值,通常用于以下目的:

? 防止彩虹表攻擊:彩虹表是一種預計算的哈希表,用于快速破解密碼。通過在密碼中添加鹽值,可以顯著增加彩虹表攻擊的難度。

? 增加加密的復雜性:鹽值可以增加加密的復雜性,使攻擊者更難破解加密數據。

三、使用 AES 和鹽值的示例

以下是一個使用 Java 實現 AES 加密和解密的示例,結合鹽值來增強安全性。

1.生成鹽值

import java.security.SecureRandom;public class SaltGenerator {public static byte[] generateSalt(int length) {SecureRandom random = new SecureRandom();byte[] salt = new byte[length];random.nextBytes(salt);return salt;}
}

2.AES 加密和解密

import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;public class AesEncryption {private static final String ALGORITHM = "AES/CBC/PKCS5Padding";public static String encrypt(String data, byte[] key, byte[] salt) throws Exception {SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");IvParameterSpec ivParameterSpec = new IvParameterSpec(salt);Cipher cipher = Cipher.getInstance(ALGORITHM);cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec, ivParameterSpec);byte[] encryptedBytes = cipher.doFinal(data.getBytes());return Base64.getEncoder().encodeToString(encryptedBytes);}public static String decrypt(String encryptedData, byte[] key, byte[] salt) throws Exception {SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");IvParameterSpec ivParameterSpec = new IvParameterSpec(salt);Cipher cipher = Cipher.getInstance(ALGORITHM);cipher.init(Cipher.DECRYPT_MODE, secretKeySpec, ivParameterSpec);byte[] decodedBytes = Base64.getDecoder().decode(encryptedData);byte[] decryptedBytes = cipher.doFinal(decodedBytes);return new String(decryptedBytes);}
}

3.使用示例

public class AesExample {public static void main(String[] args) {try {// 生成鹽值byte[] salt = SaltGenerator.generateSalt(16);// 生成密鑰byte[] key = "mysecretkey12345".getBytes(); // 密鑰長度必須為 16、24 或 32 字節// 要加密的數據String data = "Hello, World!";// 加密String encryptedData = AesEncryption.encrypt(data, key, salt);System.out.println("Encrypted Data: " + encryptedData);// 解密String decryptedData = AesEncryption.decrypt(encryptedData, key, salt);System.out.println("Decrypted Data: " + decryptedData);} catch (Exception e) {e.printStackTrace();}}
}

四、運行效果

運行上述代碼后,輸出如下:

Encrypted Data: <加密后的字符串>
Decrypted Data: Hello, World!

五、注意事項

? 密鑰長度:

? AES 密鑰長度必須為 16、24 或 32 字節。在實際應用中,通常使用 16 字節(128 位)密鑰。

? 鹽值長度:

? 鹽值的長度通常與密鑰長度一致。在上述示例中,鹽值長度為 16 字節。

? 安全性:

? 密鑰和鹽值應該安全存儲,避免泄露。在實際應用中,可以使用密鑰管理服務(如 AWS KMS、Azure Key Vault)來管理密鑰和鹽值。

? 編碼方式:

? 加密后的數據通常使用 Base64 編碼,以便于傳輸和存儲。

六、總結

AES 是一種非常安全的對稱加密算法,結合鹽值可以進一步增強安全性。通過合理使用 AES 和鹽值,可以有效保護數據的機密性和完整性。在實際應用中,建議使用密鑰管理服務來管理密鑰和鹽值,確保數據的安全性。

static class Solution_20250529213945_28cbc4c3cf9a4c0e9dcdb1b0b4bb00e9 {static public class SaltGenerator {public static byte[] generateSalt(int length) {SecureRandom random = new SecureRandom();byte[] salt = new byte[length];random.nextBytes(salt);return salt;}}static public class AesEncryption {private static final String ALGORITHM = "AES/CBC/PKCS5Padding";public static String encrypt(String data, byte[] key, byte[] salt) throws Exception {SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");IvParameterSpec ivParameterSpec = new IvParameterSpec(salt);Cipher cipher = Cipher.getInstance(ALGORITHM);cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec, ivParameterSpec);byte[] encryptedBytes = cipher.doFinal(data.getBytes());return Base64.getEncoder().encodeToString(encryptedBytes);}public static String decrypt(String encryptedData, byte[] key, byte[] salt) throws Exception {SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");IvParameterSpec ivParameterSpec = new IvParameterSpec(salt);Cipher cipher = Cipher.getInstance(ALGORITHM);cipher.init(Cipher.DECRYPT_MODE, secretKeySpec, ivParameterSpec);byte[] decodedBytes = Base64.getDecoder().decode(encryptedData);byte[] decryptedBytes = cipher.doFinal(decodedBytes);return new String(decryptedBytes);}}public static void main(String[] args) {try {// 生成鹽值byte[] salt = SaltGenerator.generateSalt(16);// 生成密鑰byte[] key = "mysecretkey12345".getBytes(); // 密鑰長度必須為 16、24 或 32 字節// 要加密的數據String data = "Hello, World!";// 加密String encryptedData = AesEncryption.encrypt(data, key, salt);System.out.println("Encrypted Data: " + encryptedData);// 解密String decryptedData = AesEncryption.decrypt(encryptedData, key, salt);System.out.println("Decrypted Data: " + decryptedData);} catch (Exception e) {e.printStackTrace();}}}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/84916.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/84916.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/84916.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

路由器、網關和光貓三種設備有啥區別?

無論是家中Wi-Fi信號的覆蓋&#xff0c;還是企業網絡的高效運行&#xff0c;路由器、網關和光貓這些設備都扮演著不可或缺的角色。然而&#xff0c;對于大多數人來說&#xff0c;這三者的功能和區別卻像一團迷霧&#xff0c;似懂非懂。你是否曾疑惑&#xff0c;為什么家里需要光…

機頂盒CM311-5s純手機免拆刷機,全網通,當貝桌面

需要用到的工具 安卓手機一臺 甲殼蟲adb助手&#xff08;安卓app&#xff09; OTG轉換線一個&#xff08;或者用usb&#xff0c;typec雙頭的U盤一個&#xff0c;未測試&#xff09; 8g U盤一個 用到的刷機文件 1.放入手機中的文件 misc recovery 2. 放入U盤根目錄 upda…

c/c++類型別名定義

author: hjjdebug date: 2025年 05月 28日 星期三 12:54:25 CST descrip: c/c類型別名定義: 文章目錄 1. #define 是宏替換.2. c風格的typedef 通用形式 typedef type_orig alias3. c風格的using 為類型定義別名的一般格式: using alias type_orig4. using 的優點: 可以直接使…

Virtuoso中對GDS文件進行工藝庫轉換的方法

如果要對相同工藝節點下進行性能評估&#xff0c;可以嘗試將一個廠商的GDS文件轉換到另一個廠商&#xff0c;不過要注意的是不同廠商&#xff08;比如SMIC和TSMC&#xff09;之間的DRC規則&#xff0c;盡量采用兩個DRC中的約束較為緊張的廠商進行設計&#xff0c;以免轉換到另外…

Kubernetes 中部署 kube-state-metrics 及 Prometheus 監控配置實戰

文章目錄 Kubernetes 中部署 kube-state-metrics 及 Prometheus 監控配置實戰環境準備創建監控命名空間準備配置文件創建 ServiceAccount配置 RBAC 權限部署 kube-state-metrics部署node_exporter(可選)驗證服務賬號 TokenPrometheus 配置示例小結驗證增加Grafana面板增加prome…

《重塑認知:Django MVT架構的多維剖析與實踐》

MVT&#xff0c;即Model - View - Template&#xff0c;是Django框架獨特的架構模式。它看似簡單的三個字母&#xff0c;實則蘊含著深刻的設計哲學&#xff0c;如同古老智慧的密碼&#xff0c;解開了Web應用開發的復雜謎題。 模型&#xff0c;是MVT架構中的數據核心&#xff0…

【JVM】初識JVM 從字節碼文件到類的生命周期

初識JVM JVM&#xff08;Java Virtual Machine&#xff09;即 Java 虛擬機&#xff0c;是 Java 技術的核心組件之一。JVM的本質就是運行在計算機上的一個程序&#xff0c;通過軟件模擬實現了一臺抽象的計算機的功能。JVM是Java程序的運行環境&#xff0c;負責加載字節碼文件&a…

人工智能在智能零售中的創新應用與未來趨勢

隨著電子商務的蓬勃發展和消費者需求的不斷變化&#xff0c;零售行業正面臨著前所未有的挑戰和機遇。智能零售作為零售行業的重要發展方向&#xff0c;通過引入人工智能&#xff08;AI&#xff09;、物聯網&#xff08;IoT&#xff09;、大數據和云計算等前沿技術&#xff0c;正…

DeepSeek 賦能智能物流:解鎖倉儲機器人調度的無限可能

目錄 一、智能物流倉儲機器人調度現狀1.1 傳統調度面臨的挑戰1.2 現有智能調度的進展與局限 二、DeepSeek 技術探秘2.1 DeepSeek 核心技術原理2.2 DeepSeek 的獨特優勢 三、DeepSeek 在智能物流倉儲機器人調度中的創新應用3.1 智能任務分配與調度3.2 路徑規劃與避障優化3.3 實時…

Vue CLI創建vue項目,安裝插件

Vue CLI創建vue項目&#xff0c;安裝插件 一、創建項目1. 安裝Vue CLI2. 創建項目 二、安裝插件routerlesssassjquery 一、創建項目 1. 安裝Vue CLI npm install -g vue/cli2. 創建項目 vue create project cd project二、安裝插件 router npm install vue-router # 對于 …

小白成長之路-Linux程序管理(二)

文章目錄 一、源碼包&#xff08;編譯&#xff09;安裝1.安裝前先查看磁盤大小2.壓縮包的位置3.執行編譯 二、二進制安裝三、Linux操作系統啟動流程3.1概述3.2啟動流程核心階段1.電源與固件階段2.引導加載程序3.內核初始化4.systemd初始化進程5. 用戶登錄階段 四、systemd管理機…

Ansible模塊——Ansible的安裝!

Ansible 安裝 Ansible 有三種安裝方式&#xff0c;源碼安裝、發行版安裝和 Python 安裝。 使用發行版安裝或 Python 安裝兩種方式時&#xff0c;Ansible 的安裝包有兩個&#xff0c;區別如下&#xff1a; ? ansible-core&#xff1a;一種極簡語言和運行時包&#xff0c;包含…

《全面解析鴻蒙相關概念:鴻蒙、開源鴻蒙、鴻蒙 Next 有何區別》

大家好&#xff0c;這里是程序員晚楓&#xff0c;最近接了一個和鴻蒙電腦有關的商單&#xff0c;所以專門花時間研究了一下和鴻蒙有關的概念。 鴻蒙系統相關概念主要有以下三個&#xff0c;它們之間存在多方面的區別&#xff0c;以下是具體介紹&#xff1a; OpenHarmony 定義…

C# 數組與字符串:全面解析與應用實踐

在C#編程語言中&#xff0c;數組和字符串是兩種最基礎也是最重要的數據類型。無論是簡單的控制臺應用程序&#xff0c;還是復雜的企業級系統&#xff0c;數組和字符串都扮演著不可或缺的角色。本文將全面深入地探討C#中數組和字符串的特性、使用方法、性能考量以及實際應用場景…

VR 技術在農業領域或許是一抹新曙光?

在科技日新月異的今天&#xff0c;VR(虛擬現實)技術已不再局限于游戲、影視等娛樂范疇&#xff0c;正逐步滲透到各個傳統行業&#xff0c;為其帶來全新的發展契機&#xff0c;農業領域便是其中之一。VR 技術利用計算機生成三維虛擬世界&#xff0c;給予用戶視覺、聽覺、觸覺等多…

SPEAR開源程序是用于逼真演示 AI 研究的模擬器

?一、軟件介紹 文末提供程序和源碼下載 SPEAR開源程序是用于逼真具身 AI 研究的模擬器 二、AI 研究的模擬器 交互式模擬器正在成為訓練具體代理的強大工具&#xff0c;但現有的模擬器存在內容多樣性、物理交互性和視覺保真度有限的問題。我們通過引入 SPEAR&#xff1a;照片…

第1章 Redis 概述

一、Redis 簡介 Redis,Remote Dictionary Server,遠程字典服務,由意大利人Salvatore Sanfilippo(又名Antirez)開發,是一個使用ANSI C 語言編寫&#xff64;支持網絡&#xff64; 可基于內存亦可持久化的日志型&#xff64;NoSQL 開源內存數據庫,其提供多種語言的API&#xff61…

圖論學習筆記 5 - 最小樹形圖

我們不廢話&#xff0c;直接進入正題&#xff1a;最小樹形圖&#xff0c;一個名字看起來很高級的東西。 聲明&#xff1a;為了便于理解&#xff0c;可能圖片數量會有億點點多。圖片尺寸可能有的較大。 概念 最小樹形圖的英文是 Directed Minimum Spanning Tree。 相信懂英文…

力扣面試150題--完全二叉樹的節點個數

Day 51 題目描述 思路 根據完全二叉樹的規律&#xff0c;完全二叉樹的高度可以直接通過不斷地訪問左子樹就可以獲取&#xff0c;判斷左右子樹的高度: 1. 如果相等說明左子樹是滿二叉樹, 然后進一步判斷右子樹的節點數(最后一層最后出現的節點必然在右子樹中&#xff09; 2. 如…

社區造數服務接入MCP|得物技術

一、背景 ? 今年 MCP 的概念非常火&#xff0c;市面上也涌現出了一大批 MCP 相關工具。作為技術一線者&#xff0c;都會按捺不住地去實操一下&#xff0c;很早的時候就有個設想&#xff0c;如果把我們的測試工具都改造為符合 MCP 服務協議標準&#xff0c;然后全部接入 AI A…