package com.transnal.ws.cnlif.bean;
import java.security.Key;
import java.security.spec.AlgorithmParameterSpec;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
/**
* DES加密 (Byte[]加密算法)
* 可以自定义 key
* 默认采用密钥:wcun5515 ,(密钥为:生活网提供)
*
* @author RenWeigang
*
* @since 2010.09.07
*/
public class DESPlus {
/**
* 编码风格
*/
private static final String ENCODEE ="UTF-8";
/**
* 密钥 key,由生活网提供
*/
private static final String DEFAULT_KEY = "wcun5515";
/**
* 设置密钥
*/
private static byte[] des_key;
/**
* 加密算法的参数接口,IvParameterSpec是它的一个实现,规定了密钥必须是8个字节
*/
private static AlgorithmParameterSpec iv =null;
/**
* 密钥对象
*/
private static Key secretKey =null;
static{
try {
des_key = DEFAULT_KEY.getBytes(ENCODEE);
//得到密钥对象
secretKey = getKey(des_key);
//设置向量(密钥必须是8个字节,否则抛出异常)
iv = new IvParameterSpec(des_key);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 解密数据,按默认密钥(wcun5515)解密
* @param message
* 已经被加密后的字符串
* @return
* 解密后的字符串
* @throws Exception
*/
public static String decrypt(String message) throws Exception {
byte[] bytesrc = stringToHexByte(message);
Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, secretKey, iv);
byte[] retByte = cipher.doFinal(bytesrc);
return new String(retByte);
}
/**
* 解密字符串,自定义密钥解密
* @param message
* 已经被加密后的字符串
* @param key
* 解密 密钥[密钥必须为8个字节,并且与加密密钥符合]
* @return
* 解密后的字符串
* @throws Exception
*/
public static String decrypt(String message,String key) throws Exception {
if(des_key!=null)
des_key=null;
if(secretKey!=null)
secretKey=null;
if(iv!=null)
iv=null;
byte[] bytesrc=stringToHexByte(message);
Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
Key strKey = getKey(key.getBytes(ENCODEE));
//规定了密钥必须是8个字节
AlgorithmParameterSpec aiv = new IvParameterSpec(key.getBytes(ENCODEE));
cipher.init(Cipher.DECRYPT_MODE,strKey,aiv);
byte[] retByte = cipher.doFinal(bytesrc);
return new String(retByte);
}
/**
* 加密数据
* 按默认密钥(wcun5515)加密
* String明文输入,byte[]密文输出
*
* @param message
* 要加密的字符串
* @param toLowerCase
* 被加密的字符串是否转为小写 True: 小写 ; False 为不转
* @return
* @throws Exception
*/
public static byte[] encrypt(String message,boolean toLowerCase)throws Exception {
//得到加密对象Cipher
Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
//设置工作模式为加密模式,给出密钥和向量
cipher.init(Cipher.ENCRYPT_MODE, secretKey, iv);
if(toLowerCase){
//把要被加密的用户名都转为小写
message = java.net.URLEncoder.encode(message,ENCODEE).toLowerCase();
}
return cipher.doFinal(message.getBytes(ENCODEE));
}
/**
* 加密字符串(针对用户名)
* 按默认密钥(wcun5515)加密
* @param message
* 需加密的字符串
* @return
* 加密后的字符串
* @throws Exception
*/
public static String encrypt(String message)throws Exception {
return byteToHexString(encrypt(message,true),true);
}
/**
* 加密字符串
* 按默认密钥(wcun5515)加密
* @param message
* 要加密的字符串
* @param messageToLowerCase
* 被加密的字符串是否转为小写,True 为转为小写;False为默认
* @param hexStringToUpperCase
* 加密后的字符串是否转为大写,True 为转为大写;False为默认
* @return
* 加密后的字符串
* @throws Exception
*/
public static String encrypt(String message,boolean messageToLowerCase,boolean hexStringToUpperCase)throws Exception {
return byteToHexString(encrypt(message,messageToLowerCase),hexStringToUpperCase);
}
/**
* 加密字符串,自定义密钥
* @param message
* 要加密的字符串
* @param key
* 加密 密钥,[密钥为8个字节]
* @return
* 加密后的字符串
* @throws Exception
*/
public static String encrypt(String message, String key)throws Exception {
if(des_key!=null)
des_key=null;
if(secretKey!=null)
secretKey=null;
if(iv!=null)
iv=null;
Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
Key strKey = getKey(key.getBytes(ENCODEE));
//规定了密钥必须是8个字节
IvParameterSpec aiv = new IvParameterSpec(key.getBytes(ENCODEE));
cipher.init(Cipher.ENCRYPT_MODE, strKey,aiv);
byte[] hexByte = cipher.doFinal(message.getBytes(ENCODEE));
return byteToHexString(hexByte,false);
}
/**
* 将表示16进制值的字符串转换为byte数组
* @param paramString
* 需要转换的字符串
* @return
* 转换后的字节
*/
public static byte[] stringToHexByte(String paramString){
// 两个字符表示一个字节,所以字节数组长度是字符串长度除以2
byte digest[] = new byte[paramString.length() / 2];
//采用不同的算法,加密后的数据也不相同
for (int i = 0; i < digest.length; i++){
String byteString = paramString.substring(2 * i, 2 * i + 2);
int byteValue = Integer.parseInt(byteString, 16);
digest[i] = (byte) byteValue;
}
return digest;
}
/**
* 将byte数组转换为表示16进制值的字符串, 如:byte[]{8,18}转换为:0813
* 和 StringToHexByte(String paramString) 互为可逆的转换过程.
*
* @param paramByte
* 需要转换的byte数组
* @param toUpperCase
* 是否以大写的形式输出;True为大写 ;False 为默认
* @return
* 转换后的字符串
*/
public static String byteToHexString(byte paramByte[],boolean toUpperCase) {
StringBuffer hexString = new StringBuffer();
for (int i = 0; i < paramByte.length; i++) {
String plainText = Integer.toHexString(0xff & paramByte[i]);
if (plainText.length() < 2)
plainText = "0" + plainText;
hexString.append(plainText);
}
if(toUpperCase){
return hexString.toString().toUpperCase();
}
return hexString.toString();
}
/**
* 从指定字符串生成密钥,密钥所需的字节数组长度为8位 不足8位时后面补0,超出8位只取前8位
* @param arrBTmp
* 构成该字符串的字节数组
* @return
* 生成的密钥
* @throws Exception
*/
private static Key getKey(byte[] paramByte) throws Exception {
// 创建一个空的8位字节数组(默认值为0)
byte[] arrB = new byte[8];
// 将原始字节数组转换为8位
for (int i = 0; i < paramByte.length && i < arrB.length; i++) {
arrB[i] = paramByte[i];
}
// 生成密钥
Key key = new SecretKeySpec(arrB, "DES");
return key;
}
/**
* 测试类
* @param args
* @throws Exception
*/
public static void main(String[] args) throws Exception {
//默认key 加密与解密
String value = "renweigang";
System.out.println("加密数据:" + value);
String a = encrypt(value);
System.out.println("加密后的数据为:" + a);
String b = decrypt(a);
System.out.println("解密后的数据:" + b);
///////自定义key加密与解密///////////////////////////////
// String key = "wcun5515";
// String value = "renweigang";
//
// System.out.println("加密数据:" + value);
//
// String a = encrypt(value,key);
// System.out.println("加密后的数据为:" + a);
//
// String b = decrypt(a,key);
// System.out.println("解密后的数据:" + b);
}
}
分享到:
相关推荐
嵌入式八股文面试题库资料知识宝典-华为的面试试题.zip
训练导控系统设计.pdf
嵌入式八股文面试题库资料知识宝典-网络编程.zip
人脸转正GAN模型的高效压缩.pdf
少儿编程scratch项目源代码文件案例素材-几何冲刺 转瞬即逝.zip
少儿编程scratch项目源代码文件案例素材-鸡蛋.zip
嵌入式系统_USB设备枚举与HID通信_CH559单片机USB主机键盘鼠标复合设备控制_基于CH559单片机的USB主机模式设备枚举与键盘鼠标数据收发系统支持复合设备识别与HID
嵌入式八股文面试题库资料知识宝典-linux常见面试题.zip
面向智慧工地的压力机在线数据的预警应用开发.pdf
基于Unity3D的鱼类运动行为可视化研究.pdf
少儿编程scratch项目源代码文件案例素材-霍格沃茨魔法学校.zip
少儿编程scratch项目源代码文件案例素材-金币冲刺.zip
内容概要:本文深入探讨了HarmonyOS编译构建子系统的作用及其技术细节。作为鸿蒙操作系统背后的关键技术之一,编译构建子系统通过GN和Ninja工具实现了高效的源代码到机器代码的转换,确保了系统的稳定性和性能优化。该系统不仅支持多系统版本构建、芯片厂商定制,还具备强大的调试与维护能力。其高效编译速度、灵活性和可扩展性使其在华为设备和其他智能终端中发挥了重要作用。文章还比较了HarmonyOS编译构建子系统与安卓和iOS编译系统的异同,并展望了其未来的发展趋势和技术演进方向。; 适合人群:对操作系统底层技术感兴趣的开发者、工程师和技术爱好者。; 使用场景及目标:①了解HarmonyOS编译构建子系统的基本概念和工作原理;②掌握其在不同设备上的应用和优化策略;③对比HarmonyOS与安卓、iOS编译系统的差异;④探索其未来发展方向和技术演进路径。; 其他说明:本文详细介绍了HarmonyOS编译构建子系统的架构设计、核心功能和实际应用案例,强调了其在万物互联时代的重要性和潜力。阅读时建议重点关注编译构建子系统的独特优势及其对鸿蒙生态系统的深远影响。
嵌入式八股文面试题库资料知识宝典-奇虎360 2015校园招聘C++研发工程师笔试题.zip
嵌入式八股文面试题库资料知识宝典-腾讯2014校园招聘C语言笔试题(附答案).zip
双种群变异策略改进RWCE算法优化换热网络.pdf
内容概要:本文详细介绍了基于瞬时无功功率理论的三电平有源电力滤波器(APF)仿真研究。主要内容涵盖并联型APF的工作原理、三相三电平NPC结构、谐波检测方法(ipiq)、双闭环控制策略(电压外环+电流内环PI控制)以及SVPWM矢量调制技术。仿真结果显示,在APF投入前后,电网电流THD从21.9%降至3.77%,显著提高了电能质量。 适用人群:从事电力系统研究、电力电子技术开发的专业人士,尤其是对有源电力滤波器及其仿真感兴趣的工程师和技术人员。 使用场景及目标:适用于需要解决电力系统中谐波污染和无功补偿问题的研究项目。目标是通过仿真验证APF的有效性和可行性,优化电力系统的电能质量。 其他说明:文中提到的仿真模型涉及多个关键模块,如三相交流电压模块、非线性负载、信号采集模块、LC滤波器模块等,这些模块的设计和协同工作对于实现良好的谐波抑制和无功补偿至关重要。
内容概要:本文探讨了在工业自动化和物联网交汇背景下,构建OPC DA转MQTT网关软件的需求及其具体实现方法。文中详细介绍了如何利用Python编程语言及相关库(如OpenOPC用于读取OPC DA数据,paho-mqtt用于MQTT消息传递),完成从OPC DA数据解析、格式转换到最终通过MQTT协议发布数据的关键步骤。此外,还讨论了针对不良网络环境下数据传输优化措施以及后续测试验证过程。 适合人群:从事工业自动化系统集成、物联网项目开发的技术人员,特别是那些希望提升跨协议数据交换能力的专业人士。 使用场景及目标:适用于需要在不同通信协议间建立高效稳定的数据通道的应用场合,比如制造业生产线监控、远程设备管理等。主要目的是克服传统有线网络限制,实现在不稳定无线网络条件下仍能保持良好性能的数据传输。 其他说明:文中提供了具体的代码片段帮助理解整个流程,并强调了实际部署过程中可能遇到的问题及解决方案。
基于C#实现的检测小说章节的重复、缺失、广告等功能+源码+项目文档,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档 基于C#实现的检测小说章节的重复、缺失、广告等功能+源码+项目文档,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档~ 基于C#实现的检测小说章节的重复、缺失、广告等功能+源码+项目文档,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档 基于C#实现的检测小说章节的重复、缺失、广告等功能+源码+项目文档,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档 基于C#实现的检测小说章节的重复、缺失、广告等功能+源码+项目文档,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档 基于C#实现的检测小说章节的重复、缺失、广告等功能+源码+项目文档,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档
少儿编程scratch项目源代码文件案例素材-火柴人终极之战.zip