欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

DES加密解密

程序员文章站 2024-03-14 10:44:34
...
package com.dc;

import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.Security;

import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;

/* ******************  类说明  *********************
 * class       :  DcDES
 * @author     :  ncc
 * create time :  2017-12-19 上午10:19:50
 * @version    :  1.0  
 * description :  DES算法为密码*中的对称密码*,又被成为美国数据加密标准,是1972年美国IBM公司研制的
 * 对称密码*加密算法。 明文按64位进行分组, **长64位,**事实上是56位参与DES运算
 * (第8、16、24、32、40、48、56、64位是校验位, 使得每个**都有奇数个1)分组后的明文组
 * 和56位的**按位替代或交换的方法形成密文组的加密方法
 * @see        :                        
 * ************************************************/   
public class DcDES {

	// KeyGenerator 提供对称**生成器的功能,支持各种算法
	private KeyGenerator ******;
	// SecretKey 负责保存对称**
	private SecretKey deskey;
	// Cipher负责完成加密或解密工作
	private Cipher c;
	// 该字节数组负责保存加密的结果
	private byte[] cipherByte;

	/**
	 * @throws NoSuchAlgorithmException
	 * @throws NoSuchPaddingException
	 */
	public DcDES() throws NoSuchAlgorithmException, NoSuchPaddingException {
		Security.addProvider(new com.sun.crypto.provider.SunJCE());
		// 实例化支持DES算法的**生成器(算法名称命名需按规定,否则抛出异常)
		****** = KeyGenerator.getInstance("DES");
		// 生成**
		deskey = ******.generateKey();
		//生成Cipher对象,指定其支持的DES算法  
		c = Cipher.getInstance("DES"); 

	}

	/* ********************************************
	 * method name   : Encrytor 
	 * description   : 对字符串加密
	 * @return       : byte[]
	 * @param        : @param str
	 * @param        : @return
	 * @param        : @throws InvalidKeyException
	 * @param        : @throws IllegalBlockSizeException
	 * @param        : @throws BadPaddingException
	 * modified      : ncc ,  2017-12-19
	 * @see          : 
	 * ********************************************/      
	public byte[] Encrytor(String str) throws InvalidKeyException,
			IllegalBlockSizeException, BadPaddingException {
		// 根据**,对Cipher对象进行初始化,ENCRYPT_MODE表示加密模式
		c.init(Cipher.ENCRYPT_MODE, deskey);
		byte[] src = str.getBytes();
		// 加密,结果保存进cipherByte
		cipherByte = c.doFinal(src);
		return cipherByte;
	}
	
	/* ********************************************
	 * method name   : Decryptor 
	 * description   : 对字符串解密
	 * @return       : byte[]
	 * @param        : @param buff
	 * @param        : @return
	 * @param        : @throws InvalidKeyException
	 * @param        : @throws IllegalBlockSizeException
	 * @param        : @throws BadPaddingException
	 * modified      : ncc ,  2017-12-19
	 * @see          : 
	 * ********************************************/      
	public byte[] Decryptor(byte[] buff) throws InvalidKeyException,
			IllegalBlockSizeException, BadPaddingException {
		// 根据**,对Cipher对象进行初始化,DECRYPT_MODE表示加密模式
		c.init(Cipher.DECRYPT_MODE, deskey);
		cipherByte = c.doFinal(buff);
		return cipherByte;
	}

	/**
	 * @param args
	 * @throws NoSuchPaddingException
	 * @throws NoSuchAlgorithmException
	 * @throws BadPaddingException
	 * @throws IllegalBlockSizeException
	 * @throws InvalidKeyException
	 */
	public static void main(String[] args) throws Exception {
		DcDES de1 = new DcDES();
		String msg = "欢迎广临得草之家!";
		byte[] encontent = de1.Encrytor(msg);
		byte[] decontent = de1.Decryptor(encontent);
		System.out.println("明文是:" + msg);
		System.out.println("加密后:" + new String(encontent));
		System.out.println("解密后:" + new String(decontent));
	}

}