java 3des加密_Java使用3DES加密解密的流程 - 3des加密解密详细解释
Java使用3DES加密解密的流程
①传入共同约定的密钥(keyBytes)以及算法(Algorithm),来构建SecretKey密钥对象
SecretKey deskey = new SecretKeySpec(keyBytes, Algorithm);
②根据算法实例化Cipher对象。它负责加密/解密
Cipher c1 = Cipher.getInstance(Algorithm);
③传入加密/解密模式以及SecretKey密钥对象,实例化Cipher对象
c1.init(Cipher.ENCRYPT_MODE, deskey);
④传入字节数组,调用Cipher.doFinal()方法,实现加密/解密,并返回一个byte字节数组
c1.doFinal(src);
3DES案例
—SecretUtils.java(3DES加密解密的工具类)—
package my3des;
import java.io.UnsupportedEncodingException;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
/**
* SecretUtils {3DES加密解密的工具类 }
* @author William
* @date 2013-04-19
*/
public class SecretUtils {
//定义加密算法,有DES、DESede(即3DES)、Blowfish
private static final String Algorithm = “DESede”;
private static final String PASSWORD_CRYPT_KEY = “2012PinganVitality075522628888ForShenZhenBelter075561869839”;
/**
* 加密方法
* @param src 源数据的字节数组
* @return
*/
public static byte[] encryptMode(byte[] src) {
try {
SecretKey deskey = new SecretKeySpec(build3DesKey(PASSWORD_CRYPT_KEY), Algorithm); //生成密钥
Cipher c1 = Cipher.getInstance(Algorithm); //实例化负责加密/解密的Cipher工具类
c1.init(Cipher.ENCRYPT_MODE, deskey); //初始化为加密模式
return c1.doFinal(src);
} catch (java.security.NoSuchAlgorithmException e1) {
e1.printStackTrace();
} catch (javax.crypto.NoSuchPaddingException e2) {
e2.printStackTrace();
} catch (java.lang.Exception e3) {
e3.printStackTrace();
}
return null;
}
/**
* 解密函数
* @param src 密文的字节数组
* @return
*/
public static byte[] decryptMode(byte[] src) {
try {
SecretKey deskey = new SecretKeySpec(build3DesKey(PASSWORD_CRYPT_KEY), Algorithm);
Cipher c1 = Cipher.getInstance(Algorithm);
c1.init(Cipher.DECRYPT_MODE, deskey); //初始化为解密模式
return c1.doFinal(src);
} catch (java.security.NoSuchAlgorithmException e1) {
e1.printStackTrace();
} catch (javax.crypto.NoSuchPaddingException e2) {
e2.printStackTrace();
} catch (java.lang.Exception e3) {
e3.printStackTrace();
}
return null;
}
/*
* 根据字符串生成密钥字节数组
* @param keyStr 密钥字符串
* @return
* @throws UnsupportedEncodingException
*/
public static byte[] build3DesKey(String keyStr) throws UnsupportedEncodingException{
byte[] key = new byte[24]; //声明一个24位的字节数组,默认里面都是0
byte[] temp = keyStr.getBytes(“UTF-8”); //将字符串转成字节数组
/*
77 * 执行数组拷贝
* System.arraycopy(源数组,从源数组哪里开始拷贝,目标数组,拷贝多少位)
*/
if(key.length 》 temp.length){
//如果temp不够24位,则拷贝temp数组整个长度的内容到key数组中
System.arraycopy(temp, 0, key, 0, temp.length);
}else{
//如果temp大于24位,则拷贝temp数组24个长度的内容到key数组中
System.arraycopy(temp, 0, key, 0, key.length);
}
return key;
}
}
—Main.java(测试类)—
package my3des;
public class Main {
/**
* @param args
*/
public static void main(String[] args) {
String msg = “3DES加密解密案例”;
System.out.println(“【加密前】:” + msg);
//加密
byte[] secretArr = SecretUtils.encryptMode(msg.getBytes());
System.out.println(“【加密后】:” + new String(secretArr));
//解密
byte[] myMsgArr = SecretUtils.decryptMode(secretArr);
System.out.println(“【解密后】:” + new String(myMsgArr));
}
}
java 3des加密_Java使用3DES加密解密的流程 - 3des加密解密详细解释相关推荐
- java 银联支付_java服务器端移动银联支付的流程
一,银联支付的整体流程 客户端提供服务器给服务器订单信息----服务器端拿到数据推送给银联指定的地址----银联给服务器端返回一个流水账号----服务器将流水账号返给客户端 ----客户端由于集成了银 ...
- java instanceof用法_Java基础高频面试题汇总(1.4W字详细解析)
注:由于公众号文章推送规则的改变,所以为了大家能够准时收到我们的文章推送,请记得将公众号:JAVA编程语言 设为星标-这样就不会错过每一篇精彩的推送啦~ 1. Java语言有哪些特点 (1)简单易学. ...
- java自动化测试报告_Java自动化测试框架-10 - TestNG之测试结果篇(详细教程)
1.-测试结果 1.1-成功,失败和断言 测试被认为是成功的,如果它不引发任何异常完成,还是它扔的预期异常(请参阅文档expectedExceptions属性上找到的@Test注释). 您的测试方法通 ...
- java 多层异常_Java多层嵌套异常处理的基本流程
异常是程序中的一些错误,但并不是所有的错误都是异常,错误有时候是可以避免的.异常的对象有两个来源,一是Java运行时环境自动抛出系统生成的异常,而不管你是否愿意捕获和处理,它总要被抛出!比如除数为0的 ...
- java testng 优化_Java自动化测试框架-10 - TestNG之测试结果篇(详细教程)
1.-测试结果 1.1-成功,失败和断言 测试被认为是成功的,如果它不引发任何异常完成,还是它扔的预期异常(请参阅文档expectedExceptions属性上找到的@Test注释). 您的测试方法通 ...
- java des3加密_JAVA加密算法(3)- 对称加密算法(DES、3DES、AES)
对称加密算法概念 加密密钥和解密密钥相同,大部分算法加密揭秘过程互逆. 特点:算法公开.(相比非对称加密)计算量小.加密速度快.效率高. 弱点:双方都使用同样的密钥,安全性得不到保证. 常用对称加密算 ...
- C# 加密解密(DES,3DES,MD5,Base64) 类
public sealed class EncryptUtils{#region Base64加密解密/// <summary>/// Base64加密/// </summary&g ...
- java 加密_Java版SMS4加密解密算法
特别说明:该专栏文章均来源自微信公众号<大数据实战演练>,欢迎关注! 前言 最近工作中需要实现HBase自定义扩展sms4加密,今天就先来说一下Java版的SMS4加密解密算法的具体实现. ...
- java string 加密_java字符串加密解密
java字符串加密解密 try { String test = "123456789@fdj.com"; EncryptionDecryption des = new Encryp ...
最新文章
- linux 程序自启
- 【leetcode记录03】动态规划
- 公众平台模板消息所在行业_微信公众号模板消息功能怎么快速推送?
- 【Unity】12.4 通过网格分层选择行进路线
- XmlParser和HtmlParser
- 加个ing是什么意思_英语中动词ed和ing形式作形容词时用法有啥区别,牢记以下要点!...
- 【毕业答辩】论文答辩过不了?做好这几点,再也不用担心自己被“仍论文”
- MenuItem 对象
- win10支持linux内核版本是多少,win10自带linux版本是多少
- Mac外接2k显示器遇到的问题
- Atitit 技术成果有哪些 1. 技术成果	1 2. 技术成果分类	2 2.1. 职务技术成果和非职务技术成果	2 2.2. 专利技术成果和非专利技术成果	2 3. 范例代码项目 与代码片段	2
- 公司收银系统要不要服务器,一套收银系统要多少成本
- QT 科学计算器与谷歌拼音输入法实现
- T1076 正常血压(信息学一本通C++)
- 完美实现无毛边异形窗体
- 丰巢的吃相到底难看在哪呢?
- 大物笔记(顺便记记)
- 一种在程序中将十六进制转换为十进制的简单方法
- Python高级:数据库CRUD操作
- 洛达应用层开发教程系列5-程序下载
热门文章
- 肖仰华 | 领域知识图谱落地实践中的问题与对策
- 每日优鲜小程序基础组件介绍
- SpingMVC框架:fileUpload组件原理和实现
- 浏览器窗口尺寸clientHeight / scrollHeight / offsetHeight / innerHeight
- 小组会谈(2019.3.14)
- Unity3D_(API)Quaternion四元数中的Quaternion.LookRotation()
- Opencv级联分类器实现人脸识别
- 腾讯云云机安装dockers
- C#中break,continue,return,,goto,throw的区别(转)
- CRITICAL_SECTION 学习