package com.bopomofo.common;
import java.io.IOException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.security.spec.InvalidKeySpecException;
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
public class DES {
private static final byte[] desKey = "INKOO.3DES.KEY".getBytes();
public DES() {}
public static String encrypt(String plainText) {
// DES算法要求有一个可信任的随机数源
SecureRandom sr = new SecureRandom();
byte rawKeyData[] = desKey;/* 用某种方法获得密匙数据 */
String rtnStr = "";
try
{
// 从原始密匙数据创建DESKeySpec对象
DESKeySpec dks;
dks = new DESKeySpec(rawKeyData);
// 创建一个密匙工厂,然后用它把DESKeySpec转换成
// 一个SecretKey对象
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
SecretKey key = keyFactory.generateSecret(dks);
// Cipher对象实际完成加密操作
Cipher cipher = Cipher.getInstance("DES");
// 用密匙初始化Cipher对象
cipher.init(Cipher.ENCRYPT_MODE, key, sr);
// 现在,获取数据并加密
byte data[] = plainText.getBytes();/* 用某种方法获取数据 */
// 正式执行加密操作
byte encryptedData[] = cipher.doFinal(data);
rtnStr = new BASE64Encoder().encode(encryptedData);
} catch (InvalidKeyException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchAlgorithmException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvalidKeySpecException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchPaddingException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalBlockSizeException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (BadPaddingException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
return rtnStr;
}
public static String decrypt(String encryptText) {
// DES算法要求有一个可信任的随机数源
SecureRandom sr = new SecureRandom();
byte rawKeyData[] = desKey; /* 用某种方法获取原始密匙数据 */
String rtnStr = "";
try
{
// 从原始密匙数据创建一个DESKeySpec对象
DESKeySpec dks;
dks = new DESKeySpec(rawKeyData);
// 创建一个密匙工厂,然后用它把DESKeySpec对象转换成
// 一个SecretKey对象
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
SecretKey key = keyFactory.generateSecret(dks);
// Cipher对象实际完成解密操作
Cipher cipher = Cipher.getInstance("DES");
// 用密匙初始化Cipher对象
cipher.init(Cipher.DECRYPT_MODE, key, sr);
// 现在,获取数据并解密
byte encryptedData[] = (new BASE64Decoder().decodeBuffer(encryptText));/* 获得经过加密的数据 */
// 正式执行解密操作
byte decryptedData[] = cipher.doFinal(encryptedData);
rtnStr = new String(decryptedData);
} catch (InvalidKeyException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchAlgorithmException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvalidKeySpecException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchPaddingException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalBlockSizeException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
} catch (BadPaddingException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}
return rtnStr;
}
public static void main(String[] args) throws Exception {
System.out.println(encrypt("provider01"));
}
}
分享到:
相关推荐
在C++中实现DES加密解密,可以创建一个类来封装相关的操作,这样有利于代码的复用和维护。 描述中提到的"单倍双倍加密算法的实现",可能是指使用DES算法进行一次或两次加密的过程。单次DES加密使用同一个密钥对数据...
DES加密解密过程,C++实现
Java和JavaScript之间的DES加密解密是信息安全领域中的一个重要话题,主要涉及到数据的保护和通信的安全。DES(Data Encryption Standard)是一种古老的对称加密算法,尽管它在安全性上已不被视为最佳选择,但在某些...
3. 错误处理:在编写加密解密代码时,必须考虑可能出现的错误,如无效的密钥、IV,或者加密/解密过程中可能出现的异常。 总之,VB实现DES加密解密涉及.NET框架中的DESCryptoServiceProvider类,以及可能的VBA与.NET...
DES加密解密算法的C语言实现 DES(Data Encryption Standard)是一种对称密钥 BLOCK 加密算法,使用 56 位密钥对 64 位数据块进行加密。下面是 DES 加密解密算法的 C 语言实现的知识点总结。 字节与二进制转换 在...
压缩包内的“3des.exe”文件很可能是该3DES加密解密工具的可执行程序,用户可以通过运行这个程序来实现对数据的加密和解密。使用此类工具时,用户需要输入适当的密钥,并选择加密或解密模式。对于3DES,为了保证安全...
这篇C语言源代码实现了DES加密解密算法,特别适合于资源有限的环境,如STM32或51单片机。STM32系列是基于ARM Cortex-M内核的微控制器,而51单片机则是早期广泛应用的8位微处理器。在这些平台上,由于内存(RAM)资源...
对数据进行单DES或者3DES加密或者解密,如果密码长度为8字节则为DES加密或者解密
在给定的“des加密例程”中,可能包含了一个调用动态链接库(DLL)实现DES加密解密的示例代码。DLL是Windows操作系统中的一种共享库,可以被多个程序同时调用,节省内存资源并便于代码复用。这个示例可能涉及以下...
总结来说,VB6.0中实现DES加密解密涉及理解DES算法原理,利用`DESCryptoServiceProvider`类进行加密解密操作,并通过文件操作函数存储和读取加密数据。虽然DES已经过时,但在某些场景下,它仍然可以作为一个学习和...
java写的关于DES加密和解密工具,可以对字符串进行加密和解密操作
用于 Arduino 微控制器平台的 DES 和 Triples DES 加密和解密库 Arduino IDE 要安装库,下载文件并将其复制到 Arduino 开发环境的“libraries”文件夹中的子文件夹(例如“DES”)中。 该库在 Arduino Leonardo 上...
描述中提到的"加出来和你文档上的不一样我负责"可能是指提供的代码实现与文档中描述的3DES加密解密方法可能存在差异,但开发者对此负责,意味着他们对代码的正确性和可靠性有信心。"DES3encrypt"和"DES3decrypt"是...
在提供的文件列表中,`ThreeDES.java`和`Test3DES.java`很可能是3DES加密解密的Java实现代码。通常,这些类会包含用于设置密钥、初始化向量(IV)、加密和解密的函数。 - `ThreeDES.java`可能包含了3DES算法的核心...
了解和分析在线DES加密解密代码有助于我们理解加密算法的基本原理,以及如何在实际编程中实现加密和解密功能。同时,这也能帮助我们在设计和评估更复杂的安全系统时,对加密技术有更深入的认识。
在"DES加密解密源代码"中,你可以期待看到以下关键知识点: 1. **DES算法流程**:源代码会清晰地展示DES加密的完整流程,包括初始置换IP、密钥扩展、轮函数F以及逆初始置换等步骤。这有助于理解DES的工作原理。 2....
在实现DES加密解密的过程中,首先需要理解DES的基本步骤,包括初始置换、扩展置换、8轮Feistel网络、逆扩展置换和逆初始置换。在MFC环境中,这些步骤可以通过定义类和函数来实现。例如,可以创建一个名为`CDES`的类...
使用java技术编写的Des加密/解密,的工具类,已亲测可完全正确使用,无bug
标题"cryptopp的DES加密解密"指出我们将讨论的是使用Cryptopp库进行DES(Data Encryption Standard)加密与解密的方法。Cryptopp是一个强大的、免费的C++类库,提供了多种密码学算法,包括DES,用于数据的安全传输和...