DES加密解密

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.security.SecureRandom;

import javax.crypto.Cipher;
import javax.crypto.CipherInputStream;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;





public class DESUtil 
{
	/**
	 * 3DES实现: 主要有CBC,ECB实现,java默认是ECB,本算法采用默认的ECB实现
对于待加密解密的数据的填充方式:NoPadding、PKCS5Padding、SSL3Padding,默认填充方式为,PKCS5Padding,本算法采用默认的PKCS5Padding填充方式
	 */
	
	private final static String DES = "DES";
	//密码,长度要是8的倍数
	private final static String PASSWORD = "zxms10ok";
	
	
    public DESUtil() 
    {
    }
    
    /**
     * 加密
     * @param datasource byte[]
     * @return byte[]
     */
    public static  byte[] encrypt(byte[] datasource) 
    {            
        try
        {
	        SecureRandom random = new SecureRandom();
	        DESKeySpec desKey = new DESKeySpec(PASSWORD.getBytes());
	        //创建一个密匙工厂,然后用它把DESKeySpec转换成
	        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
	        SecretKey securekey = keyFactory.generateSecret(desKey);
	        //Cipher对象实际完成加密操作
	        Cipher cipher = Cipher.getInstance(DES);
	        //用密匙初始化Cipher对象
	        cipher.init(Cipher.ENCRYPT_MODE, securekey, random);
	        //现在,获取数据并加密
	        //正式执行加密操作
	        return cipher.doFinal(datasource);
        }
        catch(Throwable e)
        {
                e.printStackTrace();
        }
        return null;
    }
    
    /**
     * 解密
     * @param src byte[]
     * @return byte[]
     * @throws Exception
     */
    public static byte[] decrypt(byte[] src) throws Exception 
    {
        // DES算法要求有一个可信任的随机数源
        SecureRandom random = new SecureRandom();
        // 创建一个DESKeySpec对象
        DESKeySpec desKey = new DESKeySpec(PASSWORD.getBytes());
        // 创建一个密匙工厂
        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
        // 将DESKeySpec对象转换成SecretKey对象
        SecretKey securekey = keyFactory.generateSecret(desKey);
        // Cipher对象实际完成解密操作
        Cipher cipher = Cipher.getInstance(DES);
        // 用密匙初始化Cipher对象
        cipher.init(Cipher.DECRYPT_MODE, securekey, random);
        // 真正开始解密操作
        return cipher.doFinal(src);
    }
    
    /**
     * 加密文件
     * 
     * @param srcfile
     *            要加密的文件
     * @param destfile
     *            加密后存放的文件名
     */
    public static void encryptfile(String srcfile, String destfile) throws Exception {
        InputStream is = new FileInputStream(srcfile);
        OutputStream out = new FileOutputStream(destfile);
 
        SecureRandom random = new SecureRandom();
        DESKeySpec desKey = new DESKeySpec(PASSWORD.getBytes());
        //创建一个密匙工厂,然后用它把DESKeySpec转换成
        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
        SecretKey securekey = keyFactory.generateSecret(desKey);
        //Cipher对象实际完成加密操作
        Cipher cipher = Cipher.getInstance(DES);
        //用密匙初始化Cipher对象
        cipher.init(Cipher.ENCRYPT_MODE, securekey, random);
        CipherInputStream cis = new CipherInputStream(is, cipher);
        byte[] buffer = new byte[1024];
        int r;
        while ((r = cis.read(buffer)) > 0) {
            out.write(buffer, 0, r);
        }
        cis.close();
        is.close();
        out.close();
    }
    
    /***
     * 解密文件
     * @param destfile
     */
    public static String decryptfile(String destfile) throws Exception {
    	StringBuilder strBuilder = new StringBuilder(); 
    	
        try {
        	// DES算法要求有一个可信任的随机数源
            SecureRandom random = new SecureRandom();
            // 创建一个DESKeySpec对象
            DESKeySpec desKey = new DESKeySpec(PASSWORD.getBytes());
            // 创建一个密匙工厂
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
            // 将DESKeySpec对象转换成SecretKey对象
            SecretKey securekey = keyFactory.generateSecret(desKey);
            // Cipher对象实际完成解密操作
            Cipher cipher = Cipher.getInstance(DES);
            // 用密匙初始化Cipher对象
            cipher.init(Cipher.DECRYPT_MODE, securekey, random);
            
            InputStream is = new FileInputStream(destfile);
            
            CipherInputStream cis = new CipherInputStream(is, cipher);
            BufferedReader reader = new BufferedReader(new InputStreamReader(
                    cis));
            String line = null;
            while ((line = reader.readLine()) != null) {
            	strBuilder.append(line);
            }
            reader.close();
            cis.close();
            is.close();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        
        return strBuilder.toString();
    }
    
    /**
     * 加密字符串并保存到文件中
    * @Title: encryptStrToFile  
    * @param @param content  字符串内容
    * @param @param destfile    目标文件  
    * @return void    返回类型  
    * @throws
     */
    public static void encryptStrToFile(String content, String destfile) throws Exception
    {
    	byte[] encdata = DESUtil.encrypt(content.getBytes());
    	
    	FileOutputStream fos = new FileOutputStream(new File(destfile)); 
    	
    	try
        {
            fos.write(encdata);
        }
        finally
        {
            fos.close();
        }
    }
    
 
    }


转载于:https://my.oschina.net/w4ww/blog/664235

### DES加密解密方法概述 数据加密标准(Data Encryption Standard, DES)是一种对称加密算法,它通过一个固定的56位密钥来加密和解密数据。DES将明文分为64位的数据块,并对其进行一系列复杂的置换和替换操作以生成密文[^1]。 以下是关于DES加密解密的具体实现方式: #### 密钥长度与分组大小 DES使用的是固定长度的密钥——即56位有效密钥加上8位奇偶校验位形成64位输入密钥。每次处理的数据块也是64位长。这种设计使得DES能够快速执行加密和解密过程[^2]。 #### 加密流程描述 在加密过程中,原始消息被分割成多个64比特的小段,每一段都经过初始排列IP (Initial Permutation),随后进入由16轮迭代组成的Feistel结构,在最后一轮结束后再做一次逆向初始排列(IP^-1)[^3]。 #### 解密流程描述 由于DES采用对称密码体制,因此其解密过程实际上就是按照相反顺序重复相同的运算步骤,只是使用的子密钥次序颠倒过来而已[^4]。 下面给出Python语言中的简单示例代码展示如何利用pycryptodome库完成基本的DES加解密功能: ```python from Crypto.Cipher import DES from Crypto.Util.Padding import pad, unpad import base64 def des_encrypt(plaintext, key): cipher = DES.new(key.encode(), DES.MODE_ECB) padded_text = pad(plaintext.encode(), DES.block_size) encrypted_data = cipher.encrypt(padded_text) return base64.b64encode(encrypted_data).decode() def des_decrypt(ciphertext, key): cipher = DES.new(key.encode(), DES.MODE_ECB) decoded_ciphertext = base64.b64decode(ciphertext) decrypted_padded_data = cipher.decrypt(decoded_ciphertext) return unpad(decrypted_padded_data, DES.block_size).decode() # Example Usage key = '12345678' # Must be exactly 8 bytes long. message = "HelloWorld" ciphered_message = des_encrypt(message, key) print(f"Cipher Text: {ciphered_message}") original_message = des_decrypt(ciphered_message, key) print(f"Original Message: {original_message}") ``` 上述程序展示了基于ECB模式下的基础版DES加密/解密逻辑[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值