- 浏览: 191361 次
- 性别:
- 来自: 杭州
最新评论
-
wendongcc:
在哪里可以下载呀
Flex Builder 3 正式版破解补丁! -
IT_LDB:
mark!
Tomcat线程挂起与DBCP数据库连接池的配置优化 -
晓晨Happy:
非常有用,感谢。
Flash CS3 中fl.*类库在 FB 中如何使用 -
learnload:
的确能用,谢谢!
Flex Builder 3 正式版破解补丁! -
yinger_fei:
thanks for sharing.
Tomcat线程挂起与DBCP数据库连接池的配置优化
由于实际开发对加密解密相关算法的需要,今天网搜了篇相对较全面的一篇加密算法JAVA版,这里转载一下以供大家参考。
2.4. DESede/DES对称算法
首先生成密钥,并保存(这里并没的保存的代码,可参考DSA中的方法)
KeyGenerator keygen = KeyGenerator.getInstance(Algorithm);
SecretKey deskey = keygen.generateKey();
用密钥加密明文(myinfo),生成密文(cipherByte)
Cipher c1 = Cipher.getInstance(Algorithm);
c1.init(Cipher.ENCRYPT_MODE,deskey);
byte[] cipherByte=c1.doFinal(myinfo.getBytes());
传送密文和密钥,本文没有相应代码可参考DSA
.............
用密钥解密密文
c1 = Cipher.getInstance(Algorithm);
c1.init(Cipher.DECRYPT_MODE,deskey);
byte[] clearByte=c1.doFinal(cipherByte);
相对来说对称密钥的使用是很简单的,对于JCE来讲支技DES,DESede,Blowfish三种加密术
对于密钥的保存各传送可使用对象流或者用二进制编码,相关参考代码如下
- SecretKey deskey = keygen.generateKey();
- byte[] desEncode=deskey.getEncoded();
- javax.crypto.spec.SecretKeySpec destmp=new javax.crypto.spec.SecretKeySpec(desEncode,Algorithm);
- SecretKey mydeskey=destmp;
相关API
KeyGenerator 在DSA中已经说明,在添加JCE后在instance进可以如下参数
DES,DESede,Blowfish,HmacMD5,HmacSHA1
javax.crypto.Cipher 加/解密器
- public static final Cipher getInstance(java.lang.String transformation)
- throws java.security.NoSuchAlgorithmException, NoSuchPaddingException
返回一个指定方法的Cipher对象
参数:transformation 方法名(可用 DES,DESede,Blowfish)
public final void init(int opmode, java.security.Key key)
throws java.security.InvalidKeyException
用指定的密钥和模式初始化Cipher对象
参数:opmode 方式(ENCRYPT_MODE, DECRYPT_MODE, WRAP_MODE,UNWRAP_MODE)
key 密钥
- public final byte[] doFinal(byte[] input) throws java.lang.IllegalStateException,
- IllegalBlockSizeException, BadPaddingException
对input内的串,进行编码处理,返回处理后二进制串,是返回解密文还是加解文由init时的opmode决定
注意:本方法的执行前如果有update,是对updat和本次input全部处理,否则是本inout的内容
- /*
- 安全程序 DESede/DES测试
- */
- import java.security.*;
- import javax.crypto.*;
- public class testdes {
- public static void main(String[] args) {
- testdes my = new testdes();
- my.run();
- }
- public void run() {
- // 添加新安全算法,如果用JCE就要把它添加进去
- Security.addProvider(new com.sun.crypto.provider.SunJCE());
- String Algorithm = "DES"; // 定义 加密算法,可用 DES,DESede,Blowfish
- String myinfo = "要加密的信息";
- try {
- // 生成密钥
- KeyGenerator keygen = KeyGenerator.getInstance(Algorithm);
- SecretKey deskey = keygen.generateKey();
- // 加密
- System.out.println("加密前的二进串:" + byte2hex(myinfo.getBytes()));
- System.out.println("加密前的信息:" + myinfo);
- Cipher c1 = Cipher.getInstance(Algorithm);
- c1.init(Cipher.ENCRYPT_MODE, deskey);
- byte[] cipherByte = c1.doFinal(myinfo.getBytes());
- System.out.println("加密后的二进串:" + byte2hex(cipherByte));
- // 解密
- c1 = Cipher.getInstance(Algorithm);
- c1.init(Cipher.DECRYPT_MODE, deskey);
- byte[] clearByte = c1.doFinal(cipherByte);
- System.out.println("解密后的二进串:" + byte2hex(clearByte));
- System.out.println("解密后的信息:" + (new String(clearByte)));
- } catch (java.security.NoSuchAlgorithmException e1) {
- e1.printStackTrace();
- } catch (javax.crypto.NoSuchPaddingException e2) {
- e2.printStackTrace();
- } catch (java.lang.Exception e3) {
- e3.printStackTrace();
- }
- }
- public String byte2hex(byte[] b) // 二行制转字符串
- {
- String hs = "";
- String stmp = "";
- for (int n = 0; n < b.length; n++) {
- stmp = (java.lang.Integer.toHexString(b[n] & 0XFF));
- if (stmp.length() == 1)
- hs = hs + "0" + stmp;
- else
- hs = hs + stmp;
- if (n < b.length - 1)
- hs = hs + ":";
- }
- return hs.toUpperCase();
- }
- }
2.5. Diffie-Hellman密钥一致协议
公开密钥密码体制的奠基人Diffie和Hellman所提出的 "指数密钥一致协议"(Exponential Key Agreement Protocol),该协议不要求别的安全性先决条件,允许两名用户在公开媒体上交换信息以生成"一致"的,可以共享的密钥。在JCE的中实现用户alice生成DH类型的密钥对,如果长度用1024生成的时间请,推荐第一次生成后保存DHParameterSpec,以便下次使用直接初始化.使其速度加快
- System.out.println("ALICE: 产生 DH 对 ...");
- KeyPairGenerator aliceKpairGen = KeyPairGenerator.getInstance("DH");
- aliceKpairGen.initialize(512);
- KeyPair aliceKpair = aliceKpairGen.generateKeyPair();
alice生成公钥发送组bob
- byte[] alicePubKeyEnc = aliceKpair.getPublic().getEncoded();
bob从alice发送来的公钥中读出DH密钥对的初始参数生成bob的DH密钥对
注意这一步一定要做,要保证每个用户用相同的初始参数生成的
- DHParameterSpec dhParamSpec = ((DHPublicKey)alicePubKey).getParams();
- KeyPairGenerator bobKpairGen = KeyPairGenerator.getInstance("DH");
- bobKpairGen.initialize(dhParamSpec);
- KeyPair bobKpair = bobKpairGen.generateKeyPair();
bob根据alice的公钥生成本地的DES密钥
- KeyAgreement bobKeyAgree = KeyAgreement.getInstance("DH");
- bobKeyAgree.init(bobKpair.getPrivate());
- bobKeyAgree.doPhase(alicePubKey, true);
- SecretKey bobDesKey = bobKeyAgree.generateSecret("DES");
bob已经生成了他的DES密钥,他现把他的公钥发给alice,
- byte[] bobPubKeyEnc = bobKpair.getPublic().getEncoded();
alice根据bob的公钥生成本地的DES密钥
- //解码
- KeyAgreement aliceKeyAgree = KeyAgreement.getInstance("DH");
- aliceKeyAgree.init(aliceKpair.getPrivate());
- aliceKeyAgree.doPhase(bobPubKey, true);
- SecretKey aliceDesKey = aliceKeyAgree.generateSecret("DES");
bob和alice能过这个过程就生成了相同的DES密钥,在这种基础就可进行安全能信
常用API
java.security.KeyPairGenerator 密钥生成器类
public static KeyPairGenerator getInstance(String algorithm)
throws NoSuchAlgorithmException
以指定的算法返回一个KeyPairGenerator 对象
参数: algorithm 算法名.如:原来是DSA,现在添加了 DiffieHellman(DH)
public void initialize(int keysize)
以指定的长度初始化KeyPairGenerator对象,如果没有初始化系统以1024长度默认设置
参数:keysize 算法位长.其范围必须在 512 到 1024 之间,且必须为 64 的倍数
注意:如果用1024生长的时间很长,最好生成一次后就保存,下次就不用生成了
public void initialize(AlgorithmParameterSpec params)
throws InvalidAlgorithmParameterException
以指定参数初始化
javax.crypto.interfaces.DHPublicKey
public DHParameterSpec getParams()
返回
java.security.KeyFactory
public static KeyFactory getInstance(String algorithm)
throws NoSuchAlgorithmException
以指定的算法返回一个KeyFactory
参数: algorithm 算法名:DSH,DH
public final PublicKey generatePublic(KeySpec keySpec)
throws InvalidKeySpecException
根据指定的key说明,返回一个PublicKey对象
java.security.spec.X509EncodedKeySpec
public X509EncodedKeySpec(byte[] encodedKey)
根据指定的二进制编码的字串生成一个key的说明
参数:encodedKey 二进制编码的字串(一般能过PublicKey.getEncoded()生成)
javax.crypto.KeyAgreement 密码一至类
public static final KeyAgreement getInstance(java.lang.String algorithm)
throws java.security.NoSuchAlgorithmException
返回一个指定算法的KeyAgreement对象
参数:algorithm 算法名,现在只能是DiffieHellman(DH)
public final void init(java.security.Key key)
throws java.security.InvalidKeyException
用指定的私钥初始化
参数:key 一个私钥
public final java.security.Key doPhase(java.security.Key key,
boolean lastPhase)
throws java.security.InvalidKeyException,
java.lang.IllegalStateException
用指定的公钥进行定位,lastPhase确定这是否是最后一个公钥,对于两个用户的
情况下就可以多次定次,最后确定
参数:key 公钥
lastPhase 是否最后公钥
public final SecretKey generateSecret(java.lang.String algorithm)
throws java.lang.IllegalStateException,
java.security.NoSuchAlgorithmException,
java.security.InvalidKeyException
根据指定的算法生成密钥
参数:algorithm 加密算法(可用 DES,DESede,Blowfish)
- import java.io.*;
- import java.math.BigInteger;
- import java.security.*;
- import java.security.spec.*;
- import java.security.interfaces.*;
- import javax.crypto.*;
- import javax.crypto.spec.*;
- import javax.crypto.interfaces.*;
- import com.sun.crypto.provider.SunJCE;
- public class testDHKey {
- public static void main(String argv[]) {
- try {
- testDHKey my = new testDHKey();
- my.run();
- } catch (Exception e) {
- System.err.println(e);
- }
- }
- private void run() throws Exception {
- Security.addProvider(new com.sun.crypto.provider.SunJCE());
- System.out.println("ALICE: 产生 DH 对 ...");
- KeyPairGenerator aliceKpairGen = KeyPairGenerator.getInstance("DH");
- aliceKpairGen.initialize(512);
- KeyPair aliceKpair = aliceKpairGen.generateKeyPair(); // 生成时间长
- // 张三(Alice)生成公共密钥 alicePubKeyEnc 并发送给李四(Bob) ,
- // 比如用文件方式,socket.....
- byte[] alicePubKeyEnc = aliceKpair.getPublic().getEncoded();
- // bob接收到alice的编码后的公钥,将其解码
- KeyFactory bobKeyFac = KeyFactory.getInstance("DH");
- X509EncodedKeySpec x509KeySpec = new X509EncodedKeySpec(alicePubKeyEnc);
- PublicKey alicePubKey = bobKeyFac.generatePublic(x509KeySpec);
- System.out.println("alice公钥bob解码成功");
- // bob必须用相同的参数初始化的他的DH KEY对,所以要从Alice发给他的公开密钥,
- // 中读出参数,再用这个参数初始化他的 DH key对
- // 从alicePubKye中取alice初始化时用的参数
- DHParameterSpec dhParamSpec = ((DHPublicKey) alicePubKey).getParams();
- KeyPairGenerator bobKpairGen = KeyPairGenerator.getInstance("DH");
- bobKpairGen.initialize(dhParamSpec);
- KeyPair bobKpair = bobKpairGen.generateKeyPair();
- System.out.println("BOB: 生成 DH key 对成功");
- KeyAgreement bobKeyAgree = KeyAgreement.getInstance("DH");
- bobKeyAgree.init(bobKpair.getPrivate());
- System.out.println("BOB: 初始化本地key成功");
- // 李四(bob) 生成本地的密钥 bobDesKey
- bobKeyAgree.doPhase(alicePubKey, true);
- SecretKey bobDesKey = bobKeyAgree.generateSecret("DES");
- System.out.println("BOB: 用alice的公钥定位本地key,生成本地DES密钥成功");
- // Bob生成公共密钥 bobPubKeyEnc 并发送给Alice,
- // 比如用文件方式,socket.....,使其生成本地密钥
- byte[] bobPubKeyEnc = bobKpair.getPublic().getEncoded();
- System.out.println("BOB向ALICE发送公钥");
- // alice接收到 bobPubKeyEnc后生成bobPubKey
- // 再进行定位,使aliceKeyAgree定位在bobPubKey
- KeyFactory aliceKeyFac = KeyFactory.getInstance("DH");
- x509KeySpec = new X509EncodedKeySpec(bobPubKeyEnc);
- PublicKey bobPubKey = aliceKeyFac.generatePublic(x509KeySpec);
- System.out.println("ALICE接收BOB公钥并解码成功");
- ;
- KeyAgreement aliceKeyAgree = KeyAgreement.getInstance("DH");
- aliceKeyAgree.init(aliceKpair.getPrivate());
- System.out.println("ALICE: 初始化本地key成功");
- aliceKeyAgree.doPhase(bobPubKey, true);
- // 张三(alice) 生成本地的密钥 aliceDesKey
- SecretKey aliceDesKey = aliceKeyAgree.generateSecret("DES");
- System.out.println("ALICE: 用bob的公钥定位本地key,并生成本地DES密钥");
- if (aliceDesKey.equals(bobDesKey))
- System.out.println("张三和李四的密钥相同");
- // 现在张三和李四的本地的deskey是相同的所以,完全可以进行发送加密,接收后解密,达到
- // 安全通道的的目的
- /*
- * bob用bobDesKey密钥加密信息
- */
- Cipher bobCipher = Cipher.getInstance("DES");
- bobCipher.init(Cipher.ENCRYPT_MODE, bobDesKey);
- String bobinfo = "这是李四的机密信息";
- System.out.println("李四加密前原文:" + bobinfo);
- byte[] cleartext = bobinfo.getBytes();
- byte[] ciphertext = bobCipher.doFinal(cleartext);
- /*
- * alice用aliceDesKey密钥解密
- */
- Cipher aliceCipher = Cipher.getInstance("DES");
- aliceCipher.init(Cipher.DECRYPT_MODE, aliceDesKey);
- byte[] recovered = aliceCipher.doFinal(ciphertext);
- System.out.println("alice解密bob的信息:" + (new String(recovered)));
- if (!java.util.Arrays.equals(cleartext, recovered))
- throw new Exception("解密后与原文信息不同");
- System.out.println("解密后相同");
- }
- }
第3章小结
在加密术中生成密钥对时,密钥对的当然是越长越好,但费时也越多,请从中从实际出发选取合适的长度,大部分例码中的密钥是每次运行就从新生成,在实际的情况中是生成后在一段时间保存在文件中,再次运行直接从文件中读入,从而加快速度。当然定时更新和加强密钥保管的安全性也是必须的。
发表评论
-
java常见日志
2013-05-29 14:37 1171一、 概念 Commons-logging : a ... -
ZooKeeper典型使用场景一览
2012-06-27 20:14 1283ZooKeeper是一个高可用的分布式数据管理与系统协调 ... -
Java 8 的重要新特性以及 Java 9、10 的发展规划
2012-03-26 22:51 1623我们一直在期待着Java 8的新功能,虽然很大一部分是对Jav ... -
Tomcat5.5.12 实现Session持久化的配置
2009-03-01 22:39 2251至于Session的基本知识这里就不仔细描述,Sess ... -
Tomcat中Context容器配置详解
2009-03-01 22:11 1606Context元素代表一个web应用,运行在某个特定的 ... -
log4j 配置详解
2008-07-13 14:33 1397通常,我们都提供一个名为 log4j.properti ... -
JSTL 入门: 表达式语言(转)
2008-06-27 10:02 1062JavaServer Pages(JSP)是用于 J2EE 平 ... -
memcached 协议参照译文(转)
2008-01-18 22:09 6029协议Protocolmemcached 的客户端使用TCP链接 ... -
memcached 资料收集
2007-12-26 22:10 81官方网站 http://www.danga.com/memca ... -
集群基础概念(转)
2007-12-21 17:09 1879构造Cluster是架构师们实现Scalability与Hig ... -
JAVA 集群
2007-12-17 21:53 89JVM-level clustering Terracotta ... -
P3P解决cookie存取的跨域问题
2007-11-30 14:20 3526在一次公司网站与第三方网站合作过程中,发生了一个变态 ... -
Tomcat线程挂起与DBCP数据库连接池的配置优化
2007-11-30 13:52 13520最近网站会出现一个现象是,在并发量大的时候,Tomc ... -
DB连接池的优化设置
2007-11-26 18:37 100最近的一个项目在Hibernate使用C3P0的连接池,数据库 ... -
JAVA上加密算法的实现用例(上)
2007-11-06 13:46 1610由于实际开发对加密解密相关算法的需要,今天网搜了篇相对较全面的 ...
相关推荐
在Java中实现加密算法涉及到多个重要的概念和技术,包括单钥密码体制、消息摘要、Diffie-Hellman密钥一致协议、非对称算法和公钥体系以及数字签名。下面将详细阐述这些知识点。 **1. 单钥密码体制** 单钥密码体制,...
这个RAR压缩包文件“JAVA上加密算法的实现用例”包含了一个PDF文档,很可能是详细介绍了如何在Java环境中应用各种加密算法的实际案例。虽然没有具体的标签提供额外的信息,但我们可以基于通常的加密算法来探讨相关...
四、Java加密算法实现步骤 1. 导入相关类库:如`javax.crypto.Cipher`、`java.security.KeyPairGenerator`等。 2. 选择加密算法:如AES、RSA等。 3. 初始化Cipher对象:根据加密模式(ECB、CBC等)和填充模式...
在IBM Java环境下,我们可以利用Java Cryptography Extension (JCE) 来实现这些加密算法。JCE是Java平台的标准扩展,提供了强大的加密、解密、消息摘要和密钥生成等功能。例如,AES加密可以在Java中通过`javax....
在信息安全领域,实习项目往往是为了让学生深入理解和应用理论知识,本次实习的主题是“古典加密算法的实现”,并结合了Java的Swing库来构建图形用户界面(GUI)。实习旨在通过实际操作,帮助实习生掌握密码学的基本...
1. **实验目的**:理解AES加密算法的基本原理,掌握Java实现AES加密的步骤。 2. **实验环境**:列出所使用的开发工具、Java版本等信息。 3. **实验步骤**:详细描述如何生成密钥、加密和解密过程,以及代码实现。 4....
【压缩包子文件的文件名称列表】:"BagEncriptDemo"可能是博主提供的一个Java源代码示例文件,该文件可能包含了整个背包加密算法的实现,包括公钥和私钥的生成、加密和解密的函数,以及可能的测试用例。 总的来说,...
国密算法Java实现(含详细测试代码) 我自己按照国密文档通过Java实现SM2密码算法加密/解密、签名验签,SM3密码杂凑算法,SM4分组密码算法ECB、CBC模式加密/解密。 经过详尽的测试过后没有发现问题,但建议大家在...
综上所述,“JAVA源码很强的Java加密解密算法源码”这一主题涵盖了加密解密的基本概念、应用场景以及具体的实现方法等内容。对于Java开发者而言,深入学习这些知识不仅有助于提升自己的技术水平,还能更好地应对实际...
以下是关于DES加密算法以及Java实现的相关知识点: 1. **DES算法概述** DES是一种块加密算法,它使用56位的密钥对64位的数据块进行加密。由于其固定长度的密钥和数据块,DES在处理大量数据时可能效率较低,且56位...
在Java中实现DES加密算法,需要使用Java Cryptography Extension (JCE) 提供的相关类库,主要包括`javax.crypto.Cipher`、`java.security.SecureRandom`以及`java.security.Key`等。以下是一个简单的DESEncryption类...
本文将深入探讨在Java环境下,特别是在前后端通信中如何使用AES(Advanced Encryption Standard)加密算法进行数据的安全传输。我们将基于Spring Boot框架来构建一个实际示例,演示AES的加密与解密过程。 AES,全称...