一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語(yǔ)言 - JAVA教程 - java加密算法分享(rsa解密、對(duì)稱加密、md5加密)

java加密算法分享(rsa解密、對(duì)稱加密、md5加密)

2019-11-22 13:11Java教程網(wǎng) JAVA教程

這篇文章主要介紹了java加密算法,包括rsa解密、對(duì)稱加密、md5加密等,需要的朋友可以參考下

代碼如下:


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 {
    /**
     * 傳入名文和公鑰鑰對(duì)數(shù)據(jù)進(jìn)行RSA解密
     * <br>返回值:String
     * <br>@param src
     * <br>@param pubkey
     * <br>@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密文和私鑰對(duì)數(shù)據(jù)進(jìn)行解密
     * <br>返回值:String
     * <br>@param sec
     * <br>@param privkey
     * <br>@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);
        }

    }

    /**
     * 傳入字符串、密鑰,并加密字符串(對(duì)稱加密加密),支持:DES、AES、DESede(3DES)
     * <br>返回值:String 密文
     * <br>@param src
     * <br>@param key
     * <br>@param method(DES、AES、DESede)
     * <br>@return
     */
    //對(duì)稱加密加密
    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進(jìn)行編碼,一避免出現(xiàn)丟數(shù)據(jù)情景
            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);
        }
    }
    /**
     * 傳入字符串、密鑰、加密方式,并解密字符串(對(duì)稱加密解密密),支持:DES、AES、DESede(3DES)
     * <br>生成時(shí)間:2014年5月2日  下午1:12:13
     * <br>返回值:String 密鑰原文
     * <br>@param sec
     * <br>@param key
     * <br>@param method(DES、AES、DESede)
     * <br>@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進(jìn)行解碼,一避免出現(xiàn)丟數(shù)據(jù)情景
            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,
     * <br>返回值:String         加密后的密文
     * <br>@param src     傳入加密字符串(明文)
     * <br>@param method  指定算法(md5、md2、SHA(SHA-1,SHA1)、SHA-256、SHA-384、SHA-512)
     * <br>@return
     */
    public static String ecodingPasswd(String src,String method){

        try {
            //信息摘要算法
            MessageDigest md5 = MessageDigest.getInstance(method);
            md5.update(src.getBytes());
            byte[] encoding = md5.digest();
            //使用64進(jìn)行編碼,一避免出現(xiàn)丟數(shù)據(jù)情景
            return new String(BASE64EncoderStream.encode(encoding));
        } catch (NoSuchAlgorithmException e) {
            throw new RuntimeException(e+"加密失敗!!");
        }

    }
}

 

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 爆操| 国产情侣啪啪 | free chinese 国产精品 | 天天色天天色天天色 | 男人在线网址 | 99热在线精品播放 | 1024国产精品视频观看 | 四虎影视国产精品婷婷 | 免费99精品国产自在现线 | 亚洲图片 自拍偷拍 | 国产精品亚洲综合第一区 | 国色天香论坛社区在线视频 | 99热都是精品| 亚洲成人伦理 | 欧美人畜 | 午夜伦伦电影理论片费看 | 国产福利免费看 | 男女天堂 | free性泰国女人hd | 久久精品AV一区二区无码 | 青青草原国产视频 | 久久永久视频 | 国产精品区牛牛影院 | 亚洲99久久无色码中文字幕 | 久久综合给合久久狠狠狠… | 美女被吸乳老师羞羞漫画 | 范冰冰a级一级特级毛片 | 亚洲码和乱人伦中文一区 | 天天综合色天天综合色sb | 华人在线京东热 | 金牛网155755水心论坛黄大父母 | 国产资源一区 | 国产在线精品一区二区高清不卡 | 成人高辣h视频一区二区在线观看 | 久久99精品国产自在自线 | 国产乱码一卡二卡3卡四卡 国产乱插 | 亚洲 欧美 日韩 国产 视频 | 狠狠色婷婷丁香六月 | 国产一级特黄在线播放 | 91久久线看在观草草青青 | 国产精品第1页在线播放 |