des加密解密算法(js+java两端结果相同)
来源:互联网 发布:淘宝什么利润大 编辑:程序博客网 时间:2024/04/28 01:02
DES对称加密,是一种对称加密算法。具体原理等随便百度一下就有一大堆。 在实际应用当中,经常会遇到这样的场景:用户管理中用户的登录密码以密文的形式保存在数据库中,用户在前端登录时,系统在前端将用户填写的密码进行DES加密,将密文传递到后台再与数据库中保存的密码进行对比,如果一致则允许登录,如果不一致则不允许登录。在这个场景中,不可避免的会运用到使用js方式和java代码方式对密码进行DES加密和解密的应用。 废话不多说,这里我们前端密码的DES加密使用CryptoJS框架。CryptoJS 为 JavaScript 提供了各种各样的加密算法。目前已支持的算法包括: DES MD5 SHA-1 SHA-256 AES Rabbit MARC4 HMAC HMAC-MD5 HMAC-SHA等。 如果要使用CryptoJS中的DES加密解密功能,需要在页面中引入两个js文件。
<script type="text/javascript" src="<%=basePath%>/cryptoJS/rollups/tripledes.js" charset="UTF-8"></script> <script type="text/javascript" src="<%=basePath%>/cryptoJS/components/mode-ecb.js" charset="UTF-8"></script>
前端页面如下(KEY使用“rUqSznmiv78=”):
<%@ page language="java" pageEncoding="UTF-8"%><%String path = request.getContextPath();String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path;request.getSession().setAttribute("ContextPath",basePath);%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"><html> <head> <base href="<%=basePath%>"> <title>My JSP 'index.jsp' starting page</title> </head><!-- <script type="text/javascript" src="http://localhost:8081/CCUtil/cryptoJS/rollups/tripledes.js" charset="UTF-8"></script>--><!-- <script type="text/javascript" src="http://localhost:8081/CCUtil/cryptoJS/components/mode-ecb.js" charset="UTF-8"></script>--> <script type="text/javascript" src="<%=basePath%>/cryptoJS/rollups/tripledes.js" charset="UTF-8"></script> <script type="text/javascript" src="<%=basePath%>/cryptoJS/components/mode-ecb.js" charset="UTF-8"></script> <body> This is my JSP page. <button onclick="init()">计算</button> <br> </body> <script type="text/javascript"> function init(){ var keyHex = CryptoJS.enc.Base64.parse('rUqSznmiv78='); ///var keyHex = CryptoJS.enc.Utf8.parse('rUqSznmiv78='); var encrypted = CryptoJS.DES.encrypt('87654321', keyHex, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 }); alert(encrypted.toString()); ///alert(encrypted.ciphertext.toString(CryptoJS.enc.Base64)); // direct decrypt ciphertext var decrypted = CryptoJS.DES.decrypt({ ciphertext: CryptoJS.enc.Base64.parse(encrypted.toString()) }, keyHex, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 }); alert(decrypted.toString(CryptoJS.enc.Utf8)); } </script></html>
java代码如下(需要引用commons-codec-1.10.jar,key使用“rUqSznmiv78=”):
package cc.com;import java.security.Key;import java.security.SecureRandom;import javax.crypto.Cipher;import javax.crypto.KeyGenerator;import javax.crypto.SecretKey;import javax.crypto.SecretKeyFactory;import javax.crypto.spec.DESKeySpec;import org.apache.commons.codec.binary.Base64;/** * DES对称加密算法 * @see */public class DESCoder {// public static final String KEY_ALGORITHM = "DESede";// public static final String CIPHER_ALGORITHM = "DESede/ECB/PKCS5Padding"; public static final String KEY_ALGORITHM = "DES"; public static final String CIPHER_ALGORITHM = "DES/ECB/PKCS5Padding";// /**// * 生成密钥// * @see Java6只支持56位密钥// * @see BouncyCastle支持64位密钥,官网是http://www.bouncycastle.org/// */// public static String initkey() throws NoSuchAlgorithmException {// KeyGenerator kg = KeyGenerator.getInstance(KEY_ALGORITHM);// kg.init(168);// SecretKey secretKey = kg.generateKey();// // return Base64.encodeBase64String(secretKey.getEncoded());// } /** * 生成密钥 * @param seed 密钥 * @return 字符串 * @throws Exception 异常 */ public static String initkey() throws Exception { return initkey(null); } /** * 生成密钥 * @param seed 密钥 * @return 字符串 * @throws Exception 异常 */ public static String initkey(String seed) throws Exception { SecureRandom secureRandom = null; if(seed != null){ secureRandom = new SecureRandom(Base64.decodeBase64(seed)); }else{ secureRandom = new SecureRandom(); } KeyGenerator kg = KeyGenerator.getInstance(KEY_ALGORITHM); kg.init(secureRandom); SecretKey secretKey = kg.generateKey(); return Base64.encodeBase64String(secretKey.getEncoded()); }// /**// * 转换密钥// */// private static Key toKey(byte[] key) throws Exception {// DESedeKeySpec dks = new DESedeKeySpec(key);// SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(KEY_ALGORITHM);// SecretKey secretKey = keyFactory.generateSecret(dks);// return secretKey;// } /** * 转换密钥 */ private static SecretKey toKey(byte[] key) throws Exception { DESKeySpec keySpec = new DESKeySpec(key); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(KEY_ALGORITHM); SecretKey secretKey = keyFactory.generateSecret(keySpec); return secretKey; } /** * 加密数据 * @param data 待加密数据 * @param key 密钥 * @return 加密后的数据 */ public static String encrypt(String data, String key) throws Exception { Key k = toKey(Base64.decodeBase64(key)); Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); cipher.init(Cipher.ENCRYPT_MODE, k); byte[] encryptData = cipher.doFinal(data.getBytes()); return Base64.encodeBase64String(encryptData); } /** * 解密数据 * @param data 待解密数据 * @param key 密钥 * @return 解密后的数据 */ public static String decrypt(String data, String key) throws Exception { Key k = toKey(Base64.decodeBase64(key)); Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); cipher.init(Cipher.DECRYPT_MODE, k); return new String(cipher.doFinal(Base64.decodeBase64(data))); } public static void main(String[] args) throws Exception { String source = "87654321"; System.out.println("原文: " + source); String key = "rUqSznmiv78="; System.out.println("密钥: " + key); String encryptData = encrypt(source, key); System.out.println("加密: " + encryptData); String decryptData = decrypt(encryptData, key); System.out.println("解密: " + decryptData); }}
上面只是记录下js和java两种方式的DES加密解密方式,具体登录逻辑需要自己编码开发。
备注:附带整个测试例子。
0 0
- des加密解密算法(js+java两端结果相同)
- Java加密解密算法-DES加密解密
- Des加密(js+java结果一致)
- DES加密:js加密,java解密
- DES加密解密(JAVA)
- js前台加密 java后台解密(des)
- JAVA实现的DES加密解密算法(源程序)(lp)
- Java Cipher类 DES算法(加密与解密)
- 加密解密算法java实现(2)—DES
- DES加密、解密字符串算法(java版)
- DES加密、解密字符串算法(java版)
- DES加密、解密字符串算法(java版)
- DES加密、解密字符串算法(java版)
- DES加密解密算法JAVA实现
- DES加密、解密字符串算法(java版)
- DES加密、解密字符串算法(java版)
- DES加密、解密字符串算法(java版)
- java DES加密,解密算法实现
- 图片缓存类
- Android 自定义密码键盘
- 杨中科:我的大学生活
- 实现eclipse可视化操作
- Java web查出的数据导出为Excel的表格
- des加密解密算法(js+java两端结果相同)
- python操作数据库PostgreSQL
- iOS远程推送对代理方法调用的理解
- 使用expect自动ssh到远程主机
- Mysql数据库各查询整理
- C++继承之构造析构函数调用
- Sketch 快捷键速记表(中英对照)
- centos chown改变文件拥有者
- SQL学习笔记11——视图查询