Java の暗号化アルゴリズムを使用して機密データを暗号化および復号化するにはどうすればよいですか?
Java の暗号化アルゴリズムを使用して機密データを暗号化および復号化するにはどうすればよいですか?
現代社会では、データのセキュリティは非常に重要です。特に個人のプライバシーや機密情報に関わるデータについては、そのセキュリティを保護することが重要な課題となっています。 Java プログラミングでは、暗号化アルゴリズムを使用して機密データの暗号化と復号化を行い、データのセキュリティを確保できます。この記事では、Java の暗号化アルゴリズムを使用して機密データを暗号化および復号化する方法を紹介し、コード例を添付します。
Java は、さまざまなセキュリティ要件を満たすさまざまな暗号化アルゴリズムを提供します。最も一般的に使用される暗号化アルゴリズムは、対称暗号化アルゴリズムと非対称暗号化アルゴリズムです。対称暗号化アルゴリズムは、暗号化操作と復号化操作に同じキーを使用するため、高速ですが、安全性は比較的低くなります。非対称暗号化アルゴリズムはキーのペアを使用し、公開キーはデータの暗号化に使用され、秘密キーはデータの復号化に使用され、安全性は高くなりますが、速度は遅くなります。
以下では、対称暗号化アルゴリズム AES (Advanced Encryption Standard) を例として、Java を使用して暗号化および復号化操作を実行する方法を示します。
- まず、Java 暗号化アルゴリズムに関連するクラス ライブラリをインポートする必要があります。 Java では、暗号化アルゴリズム関連のクラス ライブラリは javax.crypto および javax.crypto.spec パッケージにあります。次のステートメントを使用して、関連するクラス ライブラリをインポートできます。
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;
- 暗号化と復号化の方法を定義します。以下はサンプル コードです。
public class EncryptionUtils {
private static final String ALGORITHM = "AES"; private static final String TRANSFORMATION = "AES/ECB/PKCS5Padding"; public static String encrypt(String key, String data) throws Exception { SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), ALGORITHM); Cipher cipher = Cipher.getInstance(TRANSFORMATION); cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec); byte[] encryptedBytes = cipher.doFinal(data.getBytes()); return Base64.getEncoder().encodeToString(encryptedBytes); } public static String decrypt(String key, String encryptedData) throws Exception { SecretKeySpec secretKeySpec = new SecretKeySpec(key.getBytes(), ALGORITHM); Cipher cipher = Cipher.getInstance(TRANSFORMATION); cipher.init(Cipher.DECRYPT_MODE, secretKeySpec); byte[] decryptedBytes = cipher.doFinal(Base64.getDecoder().decode(encryptedData)); return new String(decryptedBytes); }
}
上記のコードでは、encrypt メソッドはキーと暗号化対象のデータを受け取ります。 encrypted、暗号化されたデータを返します。decrypt メソッドはキーと復号化するデータを受け取り、復号化されたデータを返します。
- 暗号化メソッドと復号化メソッドを呼び出します。以下にサンプルコードを示します。
public class Main {
public static void main(String[] args) { try { String key = "thisismysecretkey"; String data = "Hello, World!"; System.out.println("原始数据: " + data); String encryptedData = EncryptionUtils.encrypt(key, data); System.out.println("加密后的数据: " + encryptedData); String decryptedData = EncryptionUtils.decrypt(key, encryptedData); System.out.println("解密后的数据: " + decryptedData); } catch (Exception e) { e.printStackTrace(); } }
}
上記のコードでは、最初にキー key と暗号化するデータが配置されます。定義されたデータ。次に、encrypt メソッドを呼び出してデータを暗号化し、暗号化されたデータを出力します。次に、 decrypt メソッドを呼び出して暗号化されたデータを復号し、復号されたデータを出力します。
上記の手順により、Java が提供する暗号化アルゴリズムを使用して機密データの暗号化と復号化を行うことができます。キーのセキュリティは非常に重要であるため、適切に保管する必要があることに注意してください。さらに、非対称暗号化アルゴリズムを組み合わせて、データのセキュリティをさらに向上させることができます。
概要: この記事では、Java の暗号化アルゴリズムを使用して機密データを暗号化および復号化する方法について説明します。上記のコード例を通じて、読者は暗号化と復号化の基本的な方法をすぐに習得し、実際の開発におけるデータのセキュリティを強化できると思います。
以上がJava の暗号化アルゴリズムを使用して機密データを暗号化および復号化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











この記事では、2025年の上位4つのJavaScriptフレームワーク(React、Angular、Vue、Svelte)を分析し、パフォーマンス、スケーラビリティ、将来の見通しを比較します。 強力なコミュニティと生態系のためにすべてが支配的なままですが、彼らの相対的なポップ

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します

この記事では、リモートコードの実行を可能にする重大な欠陥であるSnakeyamlのCVE-2022-1471の脆弱性について説明します。 Snakeyaml 1.33以降のSpring Bootアプリケーションをアップグレードする方法は、このリスクを軽減する方法を詳述し、その依存関係のアップデートを強調しています

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

node.js 20は、V8エンジンの改善、特により速いガベージコレクションとI/Oを介してパフォーマンスを大幅に向上させます。 新機能には、より良いWebセンブリのサポートと洗練されたデバッグツール、開発者の生産性とアプリケーション速度の向上が含まれます。

大規模な分析データセットのオープンテーブル形式であるIcebergは、データの湖のパフォーマンスとスケーラビリティを向上させます。 内部メタデータ管理を通じて、寄木細工/ORCの制限に対処し、効率的なスキーマの進化、タイムトラベル、同時wを可能にします

この記事では、キュウリの手順間でデータを共有する方法、シナリオコンテキスト、グローバル変数、引数の合格、およびデータ構造を比較する方法を調べます。 簡潔なコンテキストの使用、記述など、保守性のためのベストプラクティスを強調しています

この記事では、Lambda式、Streams API、メソッド参照、およびオプションを使用して、機能プログラミングをJavaに統合することを調べます。 それは、簡潔さと不変性を通じてコードの読みやすさと保守性の改善などの利点を強調しています
