⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 des.java

📁 采用RSA公秘钥体制和MD5签名算法的安全通信
💻 JAVA
字号:
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;

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


public class DES {
    private  Cipher cipher = null;
    private  SecretKey key = null;
    public DES(){
  	  try {
			KeyGenerator kpg = KeyGenerator.getInstance("DES");
			SecureRandom random = new SecureRandom();
			kpg.init(random);
			key = kpg.generateKey();
		} catch (NoSuchAlgorithmException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} ;
    }
    public SecretKey getSecretKey(){
  	  return this.key;
    }
    public void setSecretKey(SecretKey key){
  	  this.key = key;
    }
    public byte[] encrpty(byte[] msg){
  	  byte[] result = null;
  	  try {
  		cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
			cipher.init(Cipher.ENCRYPT_MODE, key);
			if(msg.length==8192){
				result = cipher.doFinal(msg);
			}
			else{
				result = cipher.doFinal(msg);
			}
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		//  System.out.println(result.length);
  	  return result;
  }
    public byte[] decrpty(byte[] msg){
  	  byte[] result = null;
  	  try {
  		  cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
			cipher.init(Cipher.DECRYPT_MODE, key);
			if(msg.length==8200){
				result = cipher.doFinal(msg);
			}
			else {
				result = cipher.doFinal(msg);
			}
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
  	  return result;
    }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -