java中常用的数据加密算法

2020-11-28 05:27

阅读:546

标签:des   style   blog   class   code   java   

以下为加密的工具类:

soscw.com,搜素材
import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.PrivateKey;
import java.security.PublicKey;
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;

import com.sun.mail.util.BASE64DecoderStream;
import com.sun.mail.util.BASE64EncoderStream;


public class util {
    /**
     * 传入名文和公钥钥对数据进行RSA解密
     * 
生成时间:2014年5月2日 下午2:38:13 *
返回值:String *
@param src *
@param pubkey *
@return */ public static String rsaEncoding(String src,PublicKey pubkey){ try { Cipher cip = Cipher.getInstance("RSA"); cip.init(cip.ENCRYPT_MODE, pubkey); byte[] by = cip.doFinal(src.getBytes()); return new String(BASE64EncoderStream.encode(by)); } catch (NoSuchAlgorithmException e) { throw new RuntimeException(e); } catch (NoSuchPaddingException e) { throw new RuntimeException(e); } catch (InvalidKeyException e) { throw new RuntimeException(e); } catch (IllegalBlockSizeException e) { throw new RuntimeException(e); } catch (BadPaddingException e) { throw new RuntimeException(e); } } /** * 传入RSA密文和私钥对数据进行解密 *
生成时间:2014年5月2日 下午2:37:08 *
返回值:String *
@param sec *
@param privkey *
@return */ public static String rsaDeEncoding(String sec,PrivateKey privkey){ try { Cipher cip = Cipher.getInstance("RSA"); cip.init(cip.DECRYPT_MODE, privkey); byte[] by = BASE64DecoderStream.decode(sec.getBytes()); return new String(cip.doFinal(by)); } catch (NoSuchAlgorithmException e) { throw new RuntimeException(e); } catch (NoSuchPaddingException e) { throw new RuntimeException(e); } catch (InvalidKeyException e) { throw new RuntimeException(e); } catch (IllegalBlockSizeException e) { throw new RuntimeException(e); } catch (BadPaddingException e) { throw new RuntimeException(e); } } /** * 传入字符串、密钥,并加密字符串(对称加密加密),支持:DES、AES、DESede(3DES) *
生成时间:2014年5月2日 下午12:05:44 *
返回值:String 密文 *
@param src *
@param key *
@param method(DES、AES、DESede) *
@return */ //对称加密加密 public static String doubKeyEncoding(String src,String keysrc,String method) { SecretKey key; try { //生成密钥 KeyGenerator kg = KeyGenerator.getInstance(method); //初始化此密钥生成器。 kg.init(new SecureRandom(keysrc.getBytes("utf-8"))); key = kg.generateKey(); //加密 Cipher ciph = Cipher.getInstance(method); ciph.init(Cipher.ENCRYPT_MODE, key); ciph.update(src.getBytes("utf-8")); //使用64进行编码,一避免出现丢数据情景 byte[] by = BASE64EncoderStream.encode(ciph.doFinal()); return new String(by); } catch (NoSuchAlgorithmException e) { throw new RuntimeException(e); } catch (NoSuchPaddingException e) { throw new RuntimeException(e); } catch (InvalidKeyException e) { throw new RuntimeException(e); } catch (IllegalBlockSizeException e) { throw new RuntimeException(e); } catch (BadPaddingException e) { throw new RuntimeException(e); } catch (UnsupportedEncodingException e) { throw new RuntimeException(e); } } /** * 传入字符串、密钥、加密方式,并解密字符串(对称加密解密密),支持:DES、AES、DESede(3DES) *
生成时间:2014年5月2日 下午1:12:13 *
返回值:String 密钥原文 *
@param sec *
@param key *
@param method(DES、AES、DESede) *
@return */ public static String doubKeyDencoding(String sec,String keysrc,String method) { SecretKey key; try { //生成密钥 KeyGenerator kg = KeyGenerator.getInstance(method); //初始化此密钥生成器。 kg.init(new SecureRandom(keysrc.getBytes("utf-8"))); key = kg.generateKey(); //加密 Cipher ciph = Cipher.getInstance(method); ciph.init(ciph.DECRYPT_MODE, key); //使用64进行解码,一避免出现丢数据情景 byte[] by = BASE64DecoderStream.decode(sec.getBytes()); ciph.update(by); return new String(ciph.doFinal()); } catch (NoSuchAlgorithmException e) { throw new RuntimeException(e); } catch (NoSuchPaddingException e) { throw new RuntimeException(e); } catch (InvalidKeyException e) { throw new RuntimeException(e); } catch (IllegalBlockSizeException e) { throw new RuntimeException(e); } catch (BadPaddingException e) { throw new RuntimeException(e); } catch (UnsupportedEncodingException e) { throw new RuntimeException(e); } } /** * 单向信息加密(信息摘要),支持:md5、md2、SHA(SHA-1,SHA1)、SHA-256、SHA-384、SHA-512, *
生成时间:2014年5月2日 上午11:13:44 *
返回值:String 加密后的密文 *
@param src 传入加密字符串(明文) *
@param method 指定算法(md5、md2、SHA(SHA-1,SHA1)、SHA-256、SHA-384、SHA-512) *
@return */ public static String ecodingPasswd(String src,String method){ try { //信息摘要算法 MessageDigest md5 = MessageDigest.getInstance(method); md5.update(src.getBytes()); byte[] encoding = md5.digest(); //使用64进行编码,一避免出现丢数据情景 return new String(BASE64EncoderStream.encode(encoding)); } catch (NoSuchAlgorithmException e) { throw new RuntimeException(e+"加密失败!!"); } } }
soscw.com,搜素材

以下为测试类

soscw.com,搜素材
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;
import java.security.PrivateKey;
import java.security.PublicKey;

import org.junit.Test;

import com.shuqi.utils.util;

public class test {
    @Test
    public void ecoding() {
//        //MD5 加密
//        System.out.println("md5"+util.ecodingPasswd("shuqi", "md5"));
//        System.out.println("md2"+util.ecodingPasswd("shuqi", "md2"));
//        //sha加密
//        System.out.println("sha"+util.ecodingPasswd("shuqi", "sha"));
//        System.out.println("sha-1"+util.ecodingPasswd("shuqi", "sha-1"));
//        System.out.println("sha1"+util.ecodingPasswd("shuqi", "sha1"));
//        System.out.println("sha-256"+util.ecodingPasswd("shuqi", "sha-256"));
//        System.out.println("sha-384"+util.ecodingPasswd("shuqi", "sha-384"));
//        System.out.println("sha-512"+util.ecodingPasswd("shuqi", "sha-512"));
        
//        String mi = util.doubKeyEncoding("hehe", "shuqi", "AES");
//        String ming = util.doubKeyDencoding(mi, "shuqi", "AES");
//        System.out.println("AES加密解密");
//        System.out.println("加密hehhe,密文   >>>     "+mi);
//        System.out.println("解密"+mi+",明文   >>>     "+ming);
//        
//        mi = util.doubKeyEncoding("hehe", "shuqi", "DES");
//        ming = util.doubKeyDencoding(mi, "shuqi", "DES");
//        System.out.println("DES加密解密");
//        System.out.println("加密hehhe,密文   >>>     "+mi);
//        System.out.println("解密"+mi+",明文   >>>     "+ming);
//        
//        mi = util.doubKeyEncoding("hehe", "shuqi", "DESede");
//        ming = util.doubKeyDencoding(mi, "shuqi", "DESede");
//        System.out.println("DESede加密解密");
//        System.out.println("加密hehhe,密文   >>>     "+mi);
//        System.out.println("解密"+mi+",明文   >>>     "+ming);
    
    /**
     * RSA算法的验证
     */
        try {
            //实例化一个密钥对生成器
            KeyPairGenerator kpg = KeyPairGenerator.getInstance("RSA");
            //得到密钥对对象
            KeyPair kp = kpg.genKeyPair();
            PrivateKey prikay  = kp.getPrivate();
            PublicKey  pubkey = kp.getPublic();
            
            String mi = util.rsaEncoding("shuqi", pubkey);
            String ming = util.rsaDeEncoding(mi, prikay);
            System.out.println(ming+" :: "+mi);
            
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
    }

}
soscw.com,搜素材

  参考文章:shibenjie的博文  snowolf的博文

java中常用的数据加密算法,搜素材,soscw.com

java中常用的数据加密算法

标签:des   style   blog   class   code   java   

原文地址:http://www.cnblogs.com/shuqi/p/java.html


评论


亲,登录后才可以留言!