Java DES加密实现

Posted 张玉坤

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java DES加密实现相关的知识,希望对你有一定的参考价值。

下面是代码的实现:

package com.smt.cipher.symmetry;

import java.nio.charset.Charset;
import java.security.SecureRandom;
import java.util.Base64;

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;

/**
 * DES  工具
 * @author ZHANGYUKUN
 *
 */
public class AESUtil {
	public static final String  ENCODING = Charset.defaultCharset().name();
	
	
	/**
	 * 加密
	 * @param data 原文
	 * @param cipherStr 秘钥字符字符串(8的倍数)
	 * @return
	 */
	public static String encrypt( String content , String secretkeyStr ) {
		String rt = null;
		try {
			byte[] data = getDESCipher(secretkeyStr, Cipher.ENCRYPT_MODE ).doFinal(  content.getBytes(ENCODING) );
			rt  = new String(Base64.getEncoder().encode(data), ENCODING);
		} catch (Exception e) {
			e.printStackTrace();
		}
		return rt;
	}
	
	/**
	 * 解密
	 * @param data 解密
	 * @param cipherStr 秘钥字符串(8的倍数)
	 * @return
	 */
	public static String descrypt(String data , String secretkeyStr) {
		String rt = null;
		try {
			byte[] cipher = getDESCipher(secretkeyStr, Cipher.DECRYPT_MODE ).doFinal( Base64.getDecoder().decode( data.getBytes() ) );
			rt = new String( cipher,ENCODING );
		} catch (Exception e) {
			e.printStackTrace();
		}
		return rt;
	}
	
	
	/**
	 * 得到密码
	 * @param secretkeyStr
	 * @param mode
	 * @return
	 */
	public static Cipher getDESCipher( String secretkeyStr,int mode ) {
		int remainder = secretkeyStr.length()%8;
		if( remainder != 0 ) {
			throw new RuntimeException("秘钥字符串必须是8的倍数");
		}
		
		try {
			KeyGenerator keygen =KeyGenerator.getInstance("AES");
			keygen.init(128, new SecureRandom(secretkeyStr.getBytes(ENCODING)));
			SecretKey secretKey=keygen.generateKey();
			
			Cipher  cipher = Cipher.getInstance("AES");
			cipher.init( mode ,  secretKey );
			return cipher;
		} catch (Exception e) {
			e.printStackTrace();
		}
		return null;
	}
	

}

  

测试代码:

package com.smt.cipher;

import java.security.NoSuchAlgorithmException;

import com.smt.cipher.symmetry.DESUtil;

public class Main2 {

	public static void main(String[] args) throws NoSuchAlgorithmException {
		System.out.println(   DESUtil.encrypt("测试文本DES", "abcdabcd" ) );
		System.out.println(   DESUtil.descrypt( DESUtil.encrypt("测试文本DES", "abcdabcd" ) , "abcdabcd"));
	}

}

  

 

输出结果:

 

 

 

代码git 下载地址:https://github.com/hualiuwuxin/tools.git

以上是关于Java DES加密实现的主要内容,如果未能解决你的问题,请参考以下文章

java des 加密 解密 密钥随机取得方法

java des 默认采用啥加密模式

Java DES加密实现

des加密 c++ java

JAVA和.NET使用DES对称加密的区别

80分求DES加密解密算法实现的PHP源代码