java易懂易用的MD5加密(可直接運行) (1)第1/2頁
更新時間:2008年11月21日 19:35:38 作者:
出于安全考慮,網(wǎng)絡(luò)的傳輸中經(jīng)常對傳輸數(shù)據(jù)做加密和編碼處理,其中涉及以下幾種
1、md5加密,該加密算法是單向加密,即加密的數(shù)據(jù)不能再通過解密還原。相關(guān)類包含在java.security.MessageDigest包中。
2、3-DES加密,該加密算法是可逆的,解密方可以通過與加密方約定的密鑰匙進行解密。相關(guān)類包含在javax.crypto.*包中。
3、base64編碼,是用于傳輸8bit字節(jié)代碼最常用的編碼方式。相關(guān)類在sun.misc.BASE64Decoder 和sun.misc.BASE64Encoder 中。
4、URLEncoder編碼,是一種字符編碼,保證被傳送的參數(shù)由遵循規(guī)范的文本組成。相關(guān)類在java.net.URLEncoder包中。
細節(jié):
1、進行MD5加密,得到byte[]
/**
* 進行MD5加密
* @param String 原始的SPKEY
* @return byte[] 指定加密方式為md5后的byte[]
*/
private byte[] md5(String strSrc)
{
byte[] returnByte = null;
try
{
MessageDigest md5 = MessageDigest.getInstance("MD5");
returnByte = md5.digest(strSrc.getBytes("GBK"));
}
catch(Exception e)
{
e.printStackTrace();
}
return returnByte;
}
2、得到3-DES的密鑰匙
/**
* 得到3-DES的密鑰匙
* 根據(jù)根據(jù)需要,如密鑰匙為24個字節(jié),md5加密出來的是16個字節(jié),因此后面補8個字節(jié)的0
* @param String 原始的SPKEY
* @return byte[] 指定加密方式為md5后的byte[]
*/
private byte[] getEnKey(String spKey)
{
byte[] desKey=null;
try
{
byte[] desKey1 = md5(spKey);
desKey = new byte[24];
int i = 0;
while (i < desKey1.length && i < 24) {
desKey[i] = desKey1[i];
i++;
}
if (i < 24) {
desKey[i] = 0;
i++;
}
}
catch(Exception e){
e.printStackTrace();
}
return desKey;
}
3、3-DES加密
/**
* 3-DES加密
* @param byte[] src 要進行3-DES加密的byte[]
* @param byte[] enKey 3-DES加密密鑰
* @return byte[] 3-DES加密后的byte[]
*/
public byte[] Encrypt(byte[] src,byte[] enKey)
{
byte[] encryptedData = null;
try
{
DESedeKeySpec dks = new DESedeKeySpec(enKey);
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede");
SecretKey key = keyFactory.generateSecret(dks);
Cipher cipher = Cipher.getInstance("DESede");
cipher.init(Cipher.ENCRYPT_MODE, key);
encryptedData = cipher.doFinal(src);
}
catch(Exception e)
{
e.printStackTrace();
}
return encryptedData;
}
4、對字符串進行Base64編碼
/**
* 對字符串進行Base64編碼
* @param byte[] src 要進行編碼的字符
*
* @return String 進行編碼后的字符串
*/
public String getBase64Encode(byte[] src)
{
String requestValue="";
try{
BASE64Encoder base64en = new BASE64Encoder();
requestValue=base64en.encode(src);
//System.out.println(requestValue);
}
catch(Exception e){
e.printStackTrace();
}
return requestValue;
}
2、3-DES加密,該加密算法是可逆的,解密方可以通過與加密方約定的密鑰匙進行解密。相關(guān)類包含在javax.crypto.*包中。
3、base64編碼,是用于傳輸8bit字節(jié)代碼最常用的編碼方式。相關(guān)類在sun.misc.BASE64Decoder 和sun.misc.BASE64Encoder 中。
4、URLEncoder編碼,是一種字符編碼,保證被傳送的參數(shù)由遵循規(guī)范的文本組成。相關(guān)類在java.net.URLEncoder包中。
細節(jié):
1、進行MD5加密,得到byte[]
復(fù)制代碼 代碼如下:
/**
* 進行MD5加密
* @param String 原始的SPKEY
* @return byte[] 指定加密方式為md5后的byte[]
*/
private byte[] md5(String strSrc)
{
byte[] returnByte = null;
try
{
MessageDigest md5 = MessageDigest.getInstance("MD5");
returnByte = md5.digest(strSrc.getBytes("GBK"));
}
catch(Exception e)
{
e.printStackTrace();
}
return returnByte;
}
2、得到3-DES的密鑰匙
復(fù)制代碼 代碼如下:
/**
* 得到3-DES的密鑰匙
* 根據(jù)根據(jù)需要,如密鑰匙為24個字節(jié),md5加密出來的是16個字節(jié),因此后面補8個字節(jié)的0
* @param String 原始的SPKEY
* @return byte[] 指定加密方式為md5后的byte[]
*/
private byte[] getEnKey(String spKey)
{
byte[] desKey=null;
try
{
byte[] desKey1 = md5(spKey);
desKey = new byte[24];
int i = 0;
while (i < desKey1.length && i < 24) {
desKey[i] = desKey1[i];
i++;
}
if (i < 24) {
desKey[i] = 0;
i++;
}
}
catch(Exception e){
e.printStackTrace();
}
return desKey;
}
3、3-DES加密
復(fù)制代碼 代碼如下:
/**
* 3-DES加密
* @param byte[] src 要進行3-DES加密的byte[]
* @param byte[] enKey 3-DES加密密鑰
* @return byte[] 3-DES加密后的byte[]
*/
public byte[] Encrypt(byte[] src,byte[] enKey)
{
byte[] encryptedData = null;
try
{
DESedeKeySpec dks = new DESedeKeySpec(enKey);
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede");
SecretKey key = keyFactory.generateSecret(dks);
Cipher cipher = Cipher.getInstance("DESede");
cipher.init(Cipher.ENCRYPT_MODE, key);
encryptedData = cipher.doFinal(src);
}
catch(Exception e)
{
e.printStackTrace();
}
return encryptedData;
}
4、對字符串進行Base64編碼
復(fù)制代碼 代碼如下:
/**
* 對字符串進行Base64編碼
* @param byte[] src 要進行編碼的字符
*
* @return String 進行編碼后的字符串
*/
public String getBase64Encode(byte[] src)
{
String requestValue="";
try{
BASE64Encoder base64en = new BASE64Encoder();
requestValue=base64en.encode(src);
//System.out.println(requestValue);
}
catch(Exception e){
e.printStackTrace();
}
return requestValue;
}
您可能感興趣的文章:
- Java實現(xiàn)MD5加密及解密的代碼實例分享
- 分享Java常用幾種加密算法(四種)
- java常用工具類之DES和Base64加密解密類
- java實現(xiàn)md5加密示例
- Java生成MD5加密字符串代碼實例
- 兼容PHP和Java的des加密解密代碼分享
- java使用des加密解密示例分享
- java實現(xiàn)MD5加密算法的實例代碼
- 使用java自帶des加密算法實現(xiàn)文件加密和字符串加密
- java自帶的MessageDigest實現(xiàn)文本的md5加密算法
- java 易懂易用的MD5加密(可直接運行)(2)
- 基于Java實現(xiàn)的Base64加密、解密原理代碼
- des加密解密JAVA與.NET互通實例
- java實現(xiàn)的AES加密算法完整實例
- Apache Commons DbUtils工具包使用介紹
- Apache Commons fileUpload實現(xiàn)文件上傳之一
- Apache commons fileupload文件上傳實例講解
- Apache Commons fileUpload文件上傳多個示例分享
- java利用Apache commons codec進行MD5加密,BASE64加密解密,執(zhí)行系統(tǒng)命令
相關(guān)文章
通用彈出層頁面(兼容IE、firefox)可關(guān)閉控制寬高及屏蔽背景
本人搜集整理了一個通用彈出層頁面(兼容IE、firefox)可關(guān)閉控制寬高及屏蔽背景,需要的朋友可以了解下2012-12-12一個JSP頁面導(dǎo)致的tomcat內(nèi)存溢出的解決方法
每請求一次jsp頁面就會生成一個對象,這篇文章主要介紹了一個JSP頁面導(dǎo)致的tomcat內(nèi)存溢出的解決方法,需要的朋友可以參考下2014-10-10struts2中action實現(xiàn)ModelDriven后無法返回json的解決方法
struts2中action實現(xiàn)ModelDriven后無法返回json的解決方法,需要的朋友可以參考一下2013-03-03jsp項目中更改tomcat的默認index.jsp訪問路徑的方法
如何更改tomcat的默認index.jsp訪問路徑,jsp的工程下有一個叫做WEB-INF文件夾下的web.xml打開它,按照下面的方法即可修改2013-11-11jsp利用echarts實現(xiàn)報表統(tǒng)計的實例
echarts用來做數(shù)據(jù)報表的一個展示效果了,本文介紹了jsp利用echarts實現(xiàn)報表統(tǒng)計的實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2016-10-10