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);
}
}
分享到:
相关推荐
li_3ck_02a_1118
基于MATLAB的牛顿迭代法实现
mellitz_3ck_01_0319
内容概要:文章阐述了银行采用人工智能(AI)技术替代传统系统的紧迫性和收益,讨论了通过构建现代化的数据和技术平台实现效率提升的方法,同时强调实施过程中确保数据质量和建立信任的重要性。文中提及,在金融行业中,若想优化业绩则必须拥抱AI带来的机遇,并为此进行经营模式的革新。根据Workday主办的研讨会内容,PwC金融服务风险与监管领导和Workday金融服务高层指出了大部分银行对AI认知不足的问题,强调AI在金融、人力资源以及IT等领域的广泛应用潜力及具体应用场景,如欺诈检测、技能映射和财务管理方面的作用。并且提到了AI部署过程中可能出现的技术与非技术难题及相应解决办法,鼓励金融机构及时投资建设新型基础设施,以保持竞争力。 适用人群:银行及其他金融机构管理人员;金融科技领域的专业研究人员;对企业数字化和智能化转型感兴趣的商业分析师、投资者;从事信息技术咨询工作的顾问。 使用场景及目标:本文可以帮助金融机构制定合理的技术发展战略规划,评估是否有必要推进AI技术转型,同时也为希望涉足银行科技项目的开发者提供了宝贵的市场洞察,帮助理解行业内普遍存在的困难与潜在的市场需求。此外,对于想要了解银行
matlab程序代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!
AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!
AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!
AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!
chromedriver-linux64-136.0.7058.0.zip
AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!
AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!
内容概要:本文档介绍了背压热电联产(CHP)发电厂的详细设计步骤,涵盖确定各状态点的压力、温度、比焓以及质量流率的具体方法。主要内容围绕计算净电功率、燃料消耗及其效率展开,并提供了T-s图绘制的指南。针对每个组件(如蒸汽轮机、冷凝器、除氧器等),都列出了详细的效率假设和压力损失表,为实际工程应用提供了宝贵的参考资料和操作指导。同时,该作业任务要求学生从给定初始值中选择合适的操作条件进行系统模拟,并利用课程讲义和Moodle平台资料完成计算流程。 适用人群:对能源转换和动力设备设计感兴趣的学生或者初涉该领域的工程师。 使用场景及目标:旨在帮助学员深入了解并掌握背压热电联产装置的工作原理和技术指标计算的方法论,通过实践练习提高他们的问题解决能力。 其他说明:文档强调了稳态运行假设的重要性,即物质平衡等于能量输入等于输出的原则,并鼓励参与者借助附录提供的典型操作参数图表来寻找解决问题的方向。此外,它还特别指出对于一些变量值求解可能需要迭代法来进行调整,直至获得稳定结果。提交的报告必须含有一份详细的T-s图和其他必要附件。
机器学习_市财政收入分析(含数据集)
AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!
tracy_3cd_01_0318
lusted_3cd_01_0918
题目:基于51的自动分拣系统设计 主控:AT89C52 测距模块:超声波测距模块 甲醛传感器(ADC0832+滑动变阻器模拟) 粉尘传感器(PCF8591+滑动变阻器模拟) 净化模块(继电器驱动蓝灯) 排风模块(继电器驱动绿灯) 电源电路(5V降压为3.3V供电) 显示模块(LCD1602) 声光报警 按键(3个,切换阈值选择,阈值加减) 检测物体:开关模拟 电机驱动模块(继电器驱动直流电机转动) 功能: 1.显示屏显示甲醛,粉尘浓度可以切换设置阈值。 2.通过甲醛传感器检测车间环境,大于阈值时声光报警并启动净化模块。 3.通过粉尘传感器检测车间环境,大于阈值时声光报警并启动排风模块。 4.采用超声波传感器进行物体超高监测异常(大于XX距离)时触发声光报警 5.检测到物体(开关闭合)直流电机转动(模拟传送带)
network_server
AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!
sun_01_0308