zoukankan      html  css  js  c++  java
  • AES加密

    import java.io.IOException;
    import java.io.UnsupportedEncodingException;
    import java.security.InvalidKeyException;
    import java.security.NoSuchAlgorithmException;
    import java.security.SecureRandom;
    import java.util.Scanner;
    
    import javax.crypto.BadPaddingException;
    import javax.crypto.Cipher;
    import javax.crypto.IllegalBlockSizeException;
    import javax.crypto.KeyGenerator;
    import javax.crypto.NoSuchPaddingException;
    import javax.crypto.SecretKey;
    import javax.crypto.spec.SecretKeySpec;
    
    import sun.misc.BASE64Decoder;
    import sun.misc.BASE64Encoder;
    
    
    
    public class SymmetricEncoder {
    				
    	
    	
    	public static String AESEncode(String encodeRules, String content) {
    		try {
    			
    			KeyGenerator keygen = KeyGenerator.getInstance("AES");
    			
    			SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
    			secureRandom.setSeed(encodeRules.getBytes());
    			keygen.init(128,secureRandom);
    			
    			SecretKey original_key = keygen.generateKey();
    			
    			byte[] raw = original_key.getEncoded();
    			
    			SecretKey key = new SecretKeySpec(raw, "AES");
    			
    			Cipher cipher = Cipher.getInstance("AES");
    			
    			cipher.init(Cipher.ENCRYPT_MODE, key);
    			
    			byte[] byte_encode = content.getBytes("utf-8");
    			
    			byte[] byte_AES = cipher.doFinal(byte_encode);
    			
    			String AES_encode = new String(new BASE64Encoder().encode(byte_AES));
    			
    			return AES_encode;
    		} catch (NoSuchAlgorithmException e) {
    			e.printStackTrace();
    		} catch (NoSuchPaddingException e) {
    			e.printStackTrace();
    		} catch (InvalidKeyException e) {
    			e.printStackTrace();
    		} catch (IllegalBlockSizeException e) {
    			e.printStackTrace();
    		} catch (BadPaddingException e) {
    			e.printStackTrace();
    		} catch (UnsupportedEncodingException e) {
    			e.printStackTrace();
    		}
    
    		
    		return null;
    	}
    
    	
    	public static String AESDncode(String encodeRules, String content) {
    		try {
    			
    			KeyGenerator keygen = KeyGenerator.getInstance("AES");
    			
    			SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
    			secureRandom.setSeed(encodeRules.getBytes());
    			keygen.init(128,secureRandom);
    			
    			SecretKey original_key = keygen.generateKey();
    			
    			byte[] raw = original_key.getEncoded();
    			
    			SecretKey key = new SecretKeySpec(raw, "AES");
    			
    			Cipher cipher = Cipher.getInstance("AES");
    			
    			cipher.init(Cipher.DECRYPT_MODE, key);
    			
    			byte[] byte_content = new BASE64Decoder().decodeBuffer(content);
    			
    			byte[] byte_decode = cipher.doFinal(byte_content);
    			String AES_decode = new String(byte_decode, "utf-8");
    			return AES_decode;
    		} catch (NoSuchAlgorithmException e) {
    			e.printStackTrace();
    		} catch (NoSuchPaddingException e) {
    			e.printStackTrace();
    		} catch (InvalidKeyException e) {
    			e.printStackTrace();
    		} catch (IOException e) {
    			e.printStackTrace();
    		} catch (IllegalBlockSizeException e) {
    			e.printStackTrace();
    		} catch (BadPaddingException e) {
    			e.printStackTrace();
    		}
    
    		
    		return null;
    	}
    }
    

      

  • 相关阅读:
    201671010447杨露露 实验三作业互评与改进
    实验一:通读构建之法之后提出的相关问题
    实验十四 团队项目评审&课程学习总结
    201671010452 实验四附加实验 项目互评
    201671010452 周海瑞 《英文文本统计分析》结对项目报告
    201671010452周海瑞 词频统计软件项目报告
    201671010452周海瑞 实验三作业互评与改进报告
    读《构建之法》后的疑惑
    《JavaScript DOM 编程艺术》(第二版)读书笔记(四)
    《JavaScript DOM 编程艺术》(第二版)读书笔记(二)
  • 原文地址:https://www.cnblogs.com/woftlcj/p/10109400.html
Copyright © 2011-2022 走看看