所谓加密,从应用角度就是使用指定的密钥将指定的数据进行加密。
我们不用关心具体算法的实现,只要关心应用本身需求和加密方法的使用即可。
如下是DES加密方法是用的示例,注意使用DES的话密钥长度应该是8的倍数。
package com.util; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; public class DESUtil { private static final String PASSWORD_CRYPT_KEY = "01234567";// 示例密钥 private final static String DES = "DES"; public static void main(String[] args) { System.out.println(encrypt("cuisuqiang", "12345678")); System.out.println(decrypt(encrypt("cuisuqiang", "12345678"),"12345678")); } /** * 加密 * @param src 数据 * @param key 密钥,长度必须是8的倍数 * @return 返回加密后的数据 */ private static byte[] encrypt(byte[] src, byte[] key) throws Exception { SecureRandom sr = new SecureRandom(); DESKeySpec dks = new DESKeySpec(key); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES); SecretKey securekey = keyFactory.generateSecret(dks); Cipher cipher = Cipher.getInstance(DES); cipher.init(Cipher.ENCRYPT_MODE, securekey, sr); return cipher.doFinal(src); } /** * 解密 * @param src 数据 * @param key 密钥,长度必须是8的倍数 * @return 返回解密后的原始数据 */ private static byte[] decrypt(byte[] src, byte[] key) throws Exception { SecureRandom sr = new SecureRandom(); DESKeySpec dks = new DESKeySpec(key); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES); SecretKey securekey = keyFactory.generateSecret(dks); Cipher cipher = Cipher.getInstance(DES); cipher.init(Cipher.DECRYPT_MODE, securekey, sr); return cipher.doFinal(src); } /** * 密码加密 */ public final static String encrypt(String data, String key) { try { return byte2hex(encrypt(data.getBytes(), key.getBytes())); } catch (Exception e) { e.printStackTrace(); } return null; } /** * 密码解密 */ public final static String decrypt(String data, String key) { try { return new String(decrypt(hex2byte(data), key.getBytes())); } catch (Exception e) { e.printStackTrace(); } return null; } // 字节码转换成16进制字符串 private static String byte2hex(byte bytes[]) { StringBuffer retString = new StringBuffer(); for (int i = 0; i < bytes.length; ++i) { retString.append(Integer.toHexString(0x0100 + (bytes[i] & 0x00FF)).substring(1).toUpperCase()); } return retString.toString(); } // 将16进制字符串转换成字节码 private static byte[] hex2byte(String hex) { byte[] bts = new byte[hex.length() / 2]; for (int i = 0; i < bts.length; i++) { bts[i] = (byte) Integer.parseInt(hex.substring(2 * i, 2 * i + 2),16); } return bts; } }
先加密,再将加密的内容反转。
请您到ITEYE看我的原创:http://cuisuqiang.iteye.com
或支持我的个人博客,地址:http://www.javacui.com
相关推荐
DES,DES加密算法,DES算法源码。用C写的DES加密算法。 DES,DES加密算法,DES算法源码。 DES加密算法(c语言实现) (本程序可以直接使用)
主要介绍了使用java自带des加密算法实现文件加密和字符串加密的示例,需要的朋友可以参考下
DES加密算法实现的C++类DES加密算法实现的C++类
一个调用动态链接库的des加密解密例子。
对数据进行3DES加密或者解密,如果密码长度为8字节则为DES加密或者解密
des加密算法,des加密算法,好用的东西。
有个同事咨询我有关Android DES加密的相关实现,简单的实现了一下,今天来总结一下。 其他几种加密方式: •Android数据加密之Rsa加密 •Android数据加密之Aes加密 •Android数据加密之Des加密 •Android...
易语言文本DES加密源码。@资源源码站。
对数据进行单DES或者3DES加密或者解密,如果密码长度为8字节则为DES加密或者解密
STM32上实现D3DES加密
DES 加密,RSA 加密,DES 文件加密,提供了方便文件加密接口
des加密解密工具
DES加密DES加密DES加密DES加密
采用c#, 在sql server 中调用des 加密, 解密字符串. 可自定义key
对称密码算法是指加密系统的加密密钥和解密密钥相同,或者虽然不同,但是可以从其中任意一个推导出另一个,更形象的说就是用同一把钥匙开锁和解锁。在对称密码算法的发展历史中曾出现过多种优秀的算法,包括DES、3...
有关3DES加密算法的web端js示例,有详细的加解密方法,简单明了
DES加密 解密 方法: DESr DESw 支持3DES加密 解密 类中利用函数重载的方式 实现两种加密方式 加密后为16进制字符串 使用方法: 实例化一个对象 然后就可以随便用了。 如 DES加密 解密 CString sd,sd2; yxyDES2 ...
DES加密解密过程,C++实现
DES加密解密程序的C源码.喜欢就下~~~
VB实现DES加密解密算法已测试通过如有更新另行发布