搞Java的攻城狮应该比较欣喜若狂的,不仅Sun公司的JDK提供了庞大的类库,而且还有众多的开源组织和个人不断地丰富着Java的生态系统。没错的,诸如MD5、BASE64、DES、RSA等经典加密解密算法,JDK都有提供专门的API来封装相关操作。程序猿只需要了解算法的思想,以及学习如何使用API即可。当然,针对BASE64算法,JDK仅仅提供了非常标准的实现,在某些场景下无法满足应用需求。在最后一部分,将学习Apache提供的Commons Codec对BASE64算法的扩展实现,以满足实践的需要。
<一>. MD5加密算法:
消息摘要算法第五版(Message Digest Algorithm),是一种单向加密算法,只能加密、无法解密。然而MD5加密算法已经被中国山东大学王小云教授成功破译,但是在安全性要求不高的场景下,MD5加密算法仍然具有应用价值。
1. 创建md5对象:
- MessageDigest md5 = MessageDigest.getInstance("md5");
2. 进行加密操作:
- byte[] cipherData = md5.digest(plainText.getBytes());
3. 将其中的每个字节转成十六进制字符串:byte类型的数据最高位是符号位,通过和0xff进行与操作,转换为int类型的正整数。
- String toHexStr = Integer.toHexString(cipher & 0xff);
4. 如果该正数小于16(长度为1个字符),前面拼接0占位:确保最后生成的是32位字符串。
- builder.append(toHexStr.length() == 1 ? "0" + toHexStr : toHexStr);
5. 加密转换之后的字符串为:c0bb4f54f1d8b14caf6fe1069e5f93ad
6. 完整的MD5算法应用如下所示:
- /**
- * 功能简述: 测试MD5单向加密.
- * @throws Exception
- */
- @Test
- public void test01() throws Exception {
- String plainText = "Hello , world !";
- MessageDigest md5 = MessageDigest.getInstance("md5");
- byte[] cipherData = md5.digest(plainText.getBytes());
- StringBuilder builder = new StringBuilder();
- for(byte cipher : cipherData) {
- String toHexStr = Integer.toHexString(cipher & 0xff);
- builder.append(toHexStr.length() == 1 ? "0" + toHexStr : toHexStr);
- }
- System.out.println(builder.toString());
- //c0bb4f54f1d8b14caf6fe1069e5f93ad
- }
<二>. 使用BASE64进行加密/解密:
使用BASE64算法通常用作对二进制数据进行加密,加密之后的数据不易被肉眼识别。严格来说,经过BASE64加密的数据其实没有安全性可言,因为它的加密解密算法都是公开的,典型的防菜鸟不防程序猿的呀。 经过标准的BASE64算法加密后的数据, 通常包含/、+、=等特殊符号,不适合作为url参数传递,幸运的是Apache的Commons Codec模块提供了对BASE64的进一步封装。 (参见最后一部分的说明)
1. 使用BASE64加密:
- BASE64Encoder encoder = new BASE64Encoder();
- String cipherText = encoder.encode(plainText.getBytes());
2. 使用BASE64解密:
- BASE64Decoder decoder = new BASE64Decoder();
- plainText = new String(decoder.decodeBuffer(cipherText));
3. 完整代码示例:
- /**
- * 功能简述: 使用BASE64进行双向加密/解密.
- * @throws Exception
- */
- @Test
- public void test02() throws Exception {
- BASE64Encoder encoder = new BASE64Encoder();
- BASE64Decoder decoder = new BASE64Decoder();
- String plainText = "Hello , world !";
- String cipherText = encoder.encode(plainText.getBytes());
- System.out.println("cipherText : " + cipherText);
- //cipherText : SGVsbG8gLCB3b3JsZCAh
- System.out.println("plainText : " +
- new String(decoder.decodeBuffer(cipherText)));
- //plainText : Hello , world !
<三>. 使用DES对称加密/解密:
数据加密标准算法(Data Encryption Standard),和BASE64最明显的区别就是有一个工作密钥,该密钥既用于加密、也用于解密,并且要求密钥是一个长度至少大于8位的字符串。使用DES加密、解密的核心是确保工作密钥的安全性。
1. 根据key生成密钥:
- DESKeySpec keySpec = new DESKeySpec(key.getBytes());
- SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("des");
- SecretKey secretKey = keyFactory.generateSecret(keySpec);
2. 加密操作:
- Cipher cipher = Cipher.getInstance("des");
- cipher.init(Cipher.ENCRYPT_MODE, secretKey, new SecureRandom());
- byte[] cipherData = cipher.doFinal(plainText.getBytes());
3. 为了便于观察生成的加密数据,使用BASE64再次加密:
- String cipherText = new BASE64Encoder().encode(cipherData);
生成密文如下:PtRYi3sp7TOR69UrKEIicA==
4. 解密操作:
- cipher.init(Cipher.DECRYPT_MODE, secretKey, new SecureRandom());
- byte[] plainData = cipher.doFinal(cipherData);
- String plainText = new String(plainData);
5. 完整的代码demo:
- /**
- * 功能简述: 使用DES对称加密/解密.
- * @throws Exception
- */
- @Test
- public void test03() throws Exception {
- String plainText = "Hello , world !";
- String key = "12345678"; //要求key至少长度为8个字符
- SecureRandom random = new SecureRandom();
- DESKeySpec keySpec = new DESKeySpec(key.getBytes());
- SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("des");
- SecretKey secretKey = keyFactory.generateSecret(keySpec);
- Cipher cipher = Cipher.getInstance("des");
- cipher.init(Cipher.ENCRYPT_MODE, secretKey, random);
- byte[] cipherData = cipher.doFinal(plainText.getBytes());
- System.out.println("cipherText : " + new BASE64Encoder().encode(cipherData));
- //PtRYi3sp7TOR69UrKEIicA==
- cipher.init(Cipher.DECRYPT_MODE, secretKey, random);
- byte[] plainData = cipher.doFinal(cipherData);
- System.out.println("plainText : " + new String(plainData));
- //Hello , world !
- }
<四>. 使用RSA非对称加密/解密:
RSA算法是非对称加密算法的典型代表,既能加密、又能解密。和对称加密算法比如DES的明显区别在于用于加密、解密的密钥是不同的。使用RSA算法,只要密钥足够长(一般要求1024bit),加密的信息是不能被破解的。用户通过https协议访问服务器时,就是使用非对称加密算法进行数据的加密、解密操作的。
服务器发送数据给客户端时使用私钥(private key)进行加密,并且使用加密之后的数据和私钥生成数字签名(digital signature)并发送给客户端。客户端接收到服务器发送的数据会使用公钥(public key)对数据来进行解密,并且根据加密数据和公钥验证数字签名的有效性,防止加密数据在传输过程中被第三方进行了修改。
客户端发送数据给服务器时使用公钥进行加密,服务器接收到加密数据之后使用私钥进行解密。
1. 创建密钥对KeyPair:
- KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("rsa");
- keyPairGenerator.initialize(1024); //密钥长度推荐为1024位.
- KeyPair keyPair = keyPairGenerator.generateKeyPair();
2. 获取公钥/私钥:
- PublicKey publicKey = keyPair.getPublic();
- PrivateKey privateKey = keyPair.getPrivate();
3. 服务器数据使用私钥加密:
- Cipher cipher = Cipher.getInstance("rsa");
- cipher.init(Cipher.ENCRYPT_MODE, privateKey, new SecureRandom());
- byte[] cipherData = cipher.doFinal(plainText.getBytes());
4. 用户使用公钥解密:
- cipher.init(Cipher.DECRYPT_MODE, publicKey, new SecureRandom());
- byte[] plainData = cipher.doFinal(cipherData);
5. 服务器根据私钥和加密数据生成数字签名:
- Signature signature = Signature.getInstance("MD5withRSA");
- signature.initSign(privateKey);
- signature.update(cipherData);
- byte[] signData = signature.sign();
6. 用户根据公钥、加密数据验证数据是否被修改过:
- signature.initVerify(publicKey);
- signature.update(cipherData);
- boolean status = signature.verify(signData);
7. RSA算法代码demo:
- /**
- * 功能简述: 使用RSA非对称加密/解密.
- * @throws Exception
- */
- @Test
- public void test04() throws Exception {
- String plainText = "Hello , world !";
- KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("rsa");
- keyPairGenerator.initialize(1024);
- KeyPair keyPair = keyPairGenerator.generateKeyPair();
- PublicKey publicKey = keyPair.getPublic();
- PrivateKey privateKey = keyPair.getPrivate();
- Cipher cipher = Cipher.getInstance("rsa");
- SecureRandom random = new SecureRandom();
- cipher.init(Cipher.ENCRYPT_MODE, privateKey, random);
- byte[] cipherData = cipher.doFinal(plainText.getBytes());
- System.out.println("cipherText : " + new BASE64Encoder().encode(cipherData));
- //gDsJxZM98U2GzHUtUTyZ/Ir/NXqRWKUJkl6olrLYCZHY3RnlF3olkWPZ35Dwz9BMRqaTL3oPuyVq
- //sehvHExxj9RyrWpIYnYLBSURB1KVUSLMsd/ONFOD0fnJoGtIk+T/+3yybVL8M+RI+HzbE/jdYa/+
- //yQ+vHwHqXhuzZ/N8iNg=
- cipher.init(Cipher.DECRYPT_MODE, publicKey, random);
- byte[] plainData = cipher.doFinal(cipherData);
- System.out.println("plainText : " + new String(plainData));
- //Hello , world !
- Signature signature = Signature.getInstance("MD5withRSA");
- signature.initSign(privateKey);
- signature.update(cipherData);
- byte[] signData = signature.sign();
- System.out.println("signature : " + new BASE64Encoder().encode(signData));
- //ADfoeKQn6eEHgLF8ETMXan3TfFO03R5u+cQEWtAQ2lRblLZw1DpzTlJJt1RXjU451I84v3297LhR
- //co64p6Sq3kVt84wnRsQw5mucZnY+jRZNdXpcbwh2qsh8287NM2hxWqp4OOCf/+vKKXZ3pbJMNT/4
- ///t9ewo+KYCWKOgvu5QQ=
- signature.initVerify(publicKey);
- signature.update(cipherData);
- boolean status = signature.verify(signData);
- System.out.println("status : " + status);
- //true
- }
Ok,这个blog的内容够长的了,还是在下一篇博客中对加密解密封装成一个工具类吧,然后简单介绍一下Commons Codec对BASE64的扩展支持!
相关推荐
包括了Delphi AES DES MD5 RSA BASE64 2DES 3DES Blowfish CRC32-Static SHA等 常用的加密算法用法实例,比较不错的Delphi加密实例代码了,浅显易懂而且实用的常见加密算法实例,包括字符串和文件加密解密等。
本资源提供了在Android Studio项目中使用JNI实现RSA、DES、AES以及Base64和MD5的示例。 1. **RSA**: RSA是一种非对称加密算法,它基于两个密钥——公钥和私钥。公钥可以公开,用于加密数据;而私钥必须保密,用于...
在 Vue 中,常见的加密算法包括 MD5、DES、SHA256、BASE64、SHA1、RSA 等。BASE64 只是一种编码格式,并不是加密算法,但常用于在 HTTP 环境下传递较长的标识信息。 加密算法的选择需要根据实际情况进行选择,考虑...
2. 加密过程:C#使用RSA公钥或DES密钥加密数据,Java接收并解密。 3. 解密过程:Java使用RSA私钥或DES密钥加密数据,C#接收并解密。 在实现过程中,还需要注意以下几点: - 对于RSA,确保使用相同的模数和指数进行...
本资料包涵盖了多个常见的加密算法,包括2DES、3DES、3DES3、AES、Base64、Blowfish、CRC、DES、MD5以及RSA和SHA系列。以下将对这些算法进行详细介绍。 1. **2DES(双密钥数据加密标准)**:基于DES(Data ...
本篇文章将详细讲解如何在C#中实现与Java的3DES加密以及MD5withRSA签名的对接。 3DES(Triple Data Encryption Algorithm)是一种对称加密算法,它使用了DES(Data Encryption Standard)算法三次,增强了加密强度...
这样的工具类在实际开发中非常实用,开发者可以方便地对字符串进行Base64编码解码,同时也可以进行MD5、DES和AES的加密解密操作,以满足不同层次的安全需求。 使用这些加密技术时,需要注意以下几点: - 对于敏感...
本文将详细介绍Java中常用的几种加密算法,包括但不限于DES、PBE、RSA、DH、DSA和ECC等,并提供部分示例代码以加深理解。 #### 二、基本概念 在深入讨论各种加密算法之前,我们先来了解一些基本的概念: - **加密...
MD5 单向加密 SHA1 单向加密 DES 双向,可解密 加密字符串 ...RSA加密解密及RSA签名和验证 RSA 的密钥产生 产生私钥 和公钥 RSA 方式加密 RSA的解密函数 获取Hash描述表 RSA签名 RSA 签名验证
综上所述,Android利用C++实现RSA、DES、AES、BASE64和MD5涉及多个层面的知识,包括加密理论、数值计算、数据编码以及JNI接口设计。实际应用中,这些技术可以结合使用,为Android应用提供高效且安全的数据保护机制。
本话题主要涉及了MD5算法、URLEncoding、Base64编码以及几种对称和非对称加密算法AES、DES、DESede和RSA的工具类与使用实例。接下来,我们将深入探讨这些知识点。 1. **MD5算法**:MD5(Message-Digest Algorithm 5...
本文将深入探讨标题"DESC RSA MD5等加密解密例子"所涉及的关键概念,包括DES、RSA、MD5和数字签名,以及它们在实际应用中的作用。 首先,DES(Data Encryption Standard)是一种经典的对称加密算法,它使用相同的...
本文将深入探讨如何在JavaScript(JS)客户端和Java(Android)端实现3DES加密解密以及Base64编码解码,这对于保护用户敏感信息和实现安全通信至关重要。 首先,3DES(Triple Data Encryption Standard)是一种加强...
本文将详细介绍Java中常见的几种加密算法,包括AES加密、RSA加密、DES加密、MD5哈希加密、Base64编码以及异或(XOR)加密。理解并掌握这些算法对于开发安全的应用至关重要。 首先,AES(Advanced Encryption Standard...
本文将主要介绍几种常见的加密解密算法,包括DES、PBE、RSA、DH、DSA以及ECC,并提供简单的代码示例。 首先,我们来看基本的单向加密算法。这些算法主要用于生成不可逆的散列值,以验证数据的完整性和一致性。 1. ...
这个压缩包包含了MD5、Base64、CRC32、DES、AES、Blowfish、RSA以及SHA等算法的详细使用案例,为开发者提供了丰富的参考资料。 1. **MD5(Message-Digest Algorithm 5)**:MD5是一种广泛使用的哈希函数,它将任意...
2. RSA算法的详细描述,包括数学基础、加密解密过程和安全性分析。 3. RSA密钥生成和管理的指导,如如何生成公钥和私钥对。 4. RSA在实际应用中的案例,如数字签名和SSL/TLS协议中的使用。 5. DES加密算法的详解,...
本教程主要涉及的是在Android平台上通过JNI(Java Native Interface)使用RSA、3DES和BASE64算法进行加解密操作,这些技术都是在Native层实现的,以提供更高的性能和安全性。 首先,我们来了解这些加密算法: 1. *...
JCE包括了各种加密、解密算法,如对称加密(如AES、DES)、非对称加密(如RSA、DSA)、哈希函数(如MD5、SHA)以及消息认证码(如HMAC)等。在Java中,我们可以直接使用Cipher类进行加解密操作,该类提供了初始化、...
本文将详细讨论标题和描述中提及的几种加密算法:DEC(DES),RSA,MD5和SHA,以及如何在Java中对它们进行封装以实现安全的数据处理。 1. DEC(Data Encryption Standard):也称为DES,是一种对称加密算法,基于64...