import java.io.IOException;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
public class DesTmp {
private static String strDefaultKey = "TmpWin";
private byte[] desKey;
public DesTmp(){
this.desKey = strDefaultKey.getBytes();
}
public DesTmp(String desKey) {
this.desKey = desKey.getBytes();
}
/**
* 将byte数组转换为表示16进制值的字符串, 如:byte[]{8,18}转换为:0813, 和public static byte[]
* hexStr2ByteArr(String strIn) 互为可逆的转换过程
*
* @param arrB
* 需要转换的byte数组
* @return 转换后的字符串
* @throws Exception
* 本方法不处理任何异常,所有异常全部抛出
*/
public static String byteArr2HexStr(byte[] arrB) throws Exception {
int iLen = arrB.length;
// 每个byte用两个字符才能表示,所以字符串的长度是数组长度的两倍
StringBuffer sb = new StringBuffer(iLen * 2);
for (int i = 0; i < iLen; i++) {
int intTmp = arrB[i];
// 把负数转换为正数
while (intTmp < 0) {
intTmp = intTmp + 256;
}
// 小于0F的数需要在前面补0
if (intTmp < 16) {
sb.append("0");
}
sb.append(Integer.toString(intTmp, 16));
}
return sb.toString();
}
/**
* 将表示16进制值的字符串转换为byte数组, 和public static String byteArr2HexStr(byte[] arrB)
* 互为可逆的转换过程
*
* @param strIn
* 需要转换的字符串
* @return 转换后的byte数组
* @throws Exception
* 本方法不处理任何异常,所有异常全部抛出
* @author <a href="mailto:leo841001@163.com">LiGuoQing</a>
*/
public static byte[] hexStr2ByteArr(String strIn) throws Exception {
int iLen = strIn.getBytes().length;
// 两个字符表示一个字节,所以字节数组长度是字符串长度除以2
byte[] arrOut = new byte[iLen / 2];
String strTmp;
for (int i = 0; i < iLen; i = i + 2) {
strTmp = strIn.substring(i, i + 2);
arrOut[i / 2] = (byte) Integer.parseInt(strTmp, 16);
}
return arrOut;
}
public byte[] desEncrypt(byte[] plainText) throws Exception {
SecureRandom sr = new SecureRandom();
byte rawKeyData[] = desKey;
DESKeySpec dks = new DESKeySpec(rawKeyData);
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
SecretKey key = keyFactory.generateSecret(dks);
Cipher cipher = Cipher.getInstance("DES");
cipher.init(Cipher.ENCRYPT_MODE, key, sr);
byte data[] = plainText;
byte encryptedData[] = cipher.doFinal(data);
return encryptedData;
}
public byte[] desDecrypt(byte[] encryptText) throws Exception {
SecureRandom sr = new SecureRandom();
byte rawKeyData[] = desKey;
DESKeySpec dks = new DESKeySpec(rawKeyData);
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
SecretKey key = keyFactory.generateSecret(dks);
Cipher cipher = Cipher.getInstance("DES");
cipher.init(Cipher.DECRYPT_MODE, key, sr);
byte encryptedData[] = encryptText;
byte decryptedData[] = cipher.doFinal(encryptedData);
return decryptedData;
}
public String encrypt(String input) throws Exception {
String base64 = base64Encode(desEncrypt(input.getBytes()));
base64 = base64.replace("=", "_");
base64 = base64.replace("/", "-");
base64 = base64.replace("+", "!");
base64 = base64.replace("\r\n", "");
base64 = base64.replace("\n", "");
return base64;
}
public String decrypt(String input) throws Exception {
input = input.replace("_", "=");
input = input.replace("-", "/");
input = input.replace("!", "+");
//input = input.replace("", "\r\n");
byte[] result = base64Decode(input);
return new String(desDecrypt(result));
}
public static String base64Encode(byte[] s) {
if (s == null)
return null;
BASE64Encoder b = new sun.misc.BASE64Encoder();
return b.encode(s);
}
public static byte[] base64Decode(String s) throws IOException {
if (s == null)
return null;
BASE64Decoder decoder = new BASE64Decoder();
byte[] b = decoder.decodeBuffer(s);
return b;
}
public static void main(String[] args) throws Exception {
//String input = "中国人的一切";//!NrbmCgiHDlxPr5F0wqZM6!eLxOu3cPLr!o5OZ4oVxhszMIfWRm23GxZ3UGOKLb!zxZe!s5rFqF8XZEhywjWrftBnsskzeiG
//String input = "fdkwHd6fgIfD8eCzwztf1HYVY63Tdnaumso-nfVeP4cXm-K-IiuV88OClQLoNbsop84jlkEZcYmBMNmm-Qu75hPXrZVFd!7J";
String input = "Z8IvPesWDqiyG!hGExePXLysT5fazHybq1oGZ!L3CBiDkpbhBTxVFn2F1XVri4xueNLQqhJKeKRZLHVO42eYXftBnsskzeiG";
//String input = "Pd!IipaPNSfHeZFnagGIpHI2GYVlVaHoj2pO60v9KjjXHnLfcOG0HnXTWkiXhB43vofgwTgpqqMVGrNLWR41S-luttdl7M0O-c9zuvDkwnk_//";
DesTmp crypt = new DesTmp();
System.out.println("Encode:" + crypt.encrypt(input));
System.out.println("Decode:" + crypt.decrypt(crypt.encrypt(input)));
System.out.println("result:" + crypt.decrypt(input));
}
}
分享到:
相关推荐
1. **快速加密**:用户可以快速选择需要加密的文件夹,并设置一个强密码进行加密,加密过程迅速,不影响日常工作。 2. **安全存储**:加密后的文件夹会被保存在一个安全的容器中,无法被未经授权的用户访问,即使...
"一个小巧便捷的加密软件",正如其标题所示,是一款设计精巧、易于使用的工具,旨在为用户提供简便的数据加密服务,使他们能够快速且有效地保护自己的文件不被未经授权的访问。 在描述中提到的“轻松让你的文件更...
我自己用来加密和解密密码的一个小加密实用程序。 默认情况下,使用的算法是 AES-256,密钥是从名为 ENC_KEY 的环境变量中检索的。 可以更改默认值,并且设置与可执行 JAR 一起存储在文件 config.xml 中。 依赖关系 ...
"一个超小的加密软件",如其标题所示,是一款轻量级的加密工具,它旨在为用户提供简便而有效的数据保护手段。这类软件通常体积小巧,易于安装和使用,同时又具备强大的加密能力。 加密技术的核心原理是利用特定的...
子密钥生成算法的主要思想是从一个主密钥生成其他密钥,密钥同时从层和列的方向生成。在密钥生成时,行密钥与列密钥生成互不干扰,均由上一密钥经过哈希函数生成。 实验步骤包括:读取音频文件数据、离散小波变换、...
在这个特定的场景下,我们讨论的是在微信小程序中进行数据加密,包括base64编码和AES加密。这两种技术在数据安全领域扮演着重要角色。 首先,让我们了解一下Base64编码。Base64是一种将二进制数据转换为可打印ASCII...
C写的一个 解密ASCII加密的小工具
【VB版的优盘加密小工具源码】是一款基于Visual Basic(VB)编程语言开发的U盘加密软件。VB是一种面向对象的编程语言,由微软公司推出,它以其易学易用、强大的图形用户界面(GUI)设计能力而受到程序员的青睐。这款...
在本文中,我们将深入探讨如何使用Python的PyQt5库结合Python 3.6来创建一个用户界面(UI)驱动的加密解密程序。这个小程序涵盖了四种经典的密码学加密算法:凯撒加密、维吉尼亚加密、仿射加密以及培根加密。我们将...
ECB(Electronic Codebook)模式是AES加密中的一个基本模式,适用于小规模数据的快速加密。 在微信小程序中,开发者可能会遇到需要对敏感信息,如用户密码、订单详情等进行加密传输的情况。AES的ECB模式便为此提供...
标题中的“加密小程序”指的是一个小型的程序,它专注于数据加密功能,并且无需进行常规的安装过程,方便用户快速使用。这种小程序可能采用轻量级的设计,使得在各种设备上运行更加便捷。描述中提到的“三菱ST结构...
encryptLong可能是小程序中实现的一个特定函数,用于处理这种分段加密过程。它会确保每个部分在加密后能够正确合并成原始加密结果。 2. **不分段采用encrypt**:这个方法通常是针对较小的数据或者可以直接在...
软件说明:这是一款文件夹加密软件,加密之后仍以文件夹形式保存,不需要压缩或者转换成文件的形式,所以加密速度超快! 加密之后的文件夹不仅不能访问,而且不能复制、删除、重命名...总之除了格式化之外其他的任何...
一个小巧的文件夹加密工具,迅速有效.不破坏文件解构
CBC(Cipher Block Chaining)模式是一种常用的块密码加密模式,它通过前一个密文块与当前明文块的异或操作来增加加密的复杂性和安全性。 首先,我们需要理解CBC加密的基本原理。在CBC模式中,每个明文块首先与前一...
标题提到的“一个加密小软件”旨在为用户提供一种简单而有效的文档加密手段,以保护个人隐私和敏感信息不被未经授权的人员访问。描述中强调了这款软件对文档隐私问题的关注,暗示它可能具有易用性和高效性。 标签...
加密过程通常包括选择要加密的文件或文件夹,然后设定一个密码。这个密码是解密的关键,因此需要妥善保管,避免泄露。 文件夹加密则进一步强化了数据保护。用户可以对整个文件夹进行一次性加密,所有包含在其中的...
标题中的“用Delphi写的一个DES的加密解密小程序,Java写的DES的一个类”表明了这个压缩包包含两个部分:一个是使用Delphi编程语言编写的用于执行DES(Data Encryption Standard)加密和解密的小程序,另一个是用Java...
- **随机初始化向量IV**:在某些加密模式下(如CBC),需要一个随机的初始化向量,以增加加密的复杂度,防止相同数据加密后得到相同的密文。 - **错误处理**:在加密和解密过程中可能出现错误,如密钥不匹配、数据...
《加密解密小玩具v0.6》是一款实用的加密解密软件,它集成了多种经典且常用的加密算法,如RSA、AES、BASE64、BASE32、RC4等,同时还提供了MD5和SHA系列的哈希加密功能。这款工具能够帮助用户快速对数据进行加密和...