Java Web几种加密算法.docx
- 文档编号:3085006
- 上传时间:2022-11-17
- 格式:DOCX
- 页数:15
- 大小:20.26KB
Java Web几种加密算法.docx
《Java Web几种加密算法.docx》由会员分享,可在线阅读,更多相关《Java Web几种加密算法.docx(15页珍藏版)》请在冰豆网上搜索。
JavaWeb几种加密算法
JavaWeb_几种加密算法
一.几种加密算法
1:
消息摘要:
(数字指纹):
既对一个任意长度的一个数据块进行计算,产生一个唯一指纹。
MD5/SHA1
发送给其他人你的信息和摘要,其他人用相同的加密方法得到摘要,最后进行比较摘要是否相同。
MD5的全称是Message-DigestAlgorithm5(信息-摘要算法)。
过程不可逆, 是单向加密。
SHA加密,与MD5相似的用法,只是两者的算法不同。
2:
单匙密码体制:
DES:
比较简便高效,密钥简短,加解密速度快,破译极其困难,但其安全性依赖于密匙的安全性。
DES(DataEncryptionStandard)是发明最早的最广泛使用的分组对称加密算法。
DES算法的入口参数有三个:
Key、Data、Mode。
其中Key为8个字节共64位,是DES算法的工作密钥;Data也为8个字节64位,是要被加密或被解密的数据;Mode为DES的工作方式,有两种:
加密或解密
3:
数字签名:
就是信息发送者用其私钥对从所传报文中提取出的特征数据(或称数字指纹)进行RSA算法操作,以保证发信人无法抵赖曾发过该信息(即不可抵赖性),
同时也确保信息报文在经签名后末被篡改(即完整性)。
当信息接收者收到报文后,就可以用发送者的公钥对数字签名进行验证。
代表:
DSA
4:
非对称密匙密码体制(公匙体系):
加密密匙不同于解密密匙,加密密匙公之于众,谁都可以使用,解密密匙只有解密人自己知道。
代表:
RSA
下面是对上面几个例子进行的简单实现:
二.代码解析
1.MD5/SHA
package com.text;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class MD5{
/**
* 进行MD5/SHA加密
*
* @param info
* 要加密的信息
* @return String 加密后的字符串
*/
private StringencryptToMD5(Stringstr){
byte[]byteArray=null;
try {
//得到一个MD5的消息摘要
MessageDigestmessageDigest=MessageDigest.getInstance("MD5");
// 得到一个SHA-1的消息摘要
//messageDigest=MessageDigest.getInstance("SHA-1");
// messageDigest.reset();
//添加要进行计算摘要的信息
messageDigest.update(str.getBytes());
// messageDigest.update(str.getBytes("UTF-8"));
//得到该摘要
byteArray=messageDigest.digest();
} catch (NoSuchAlgorithmException e){
e.printStackTrace();
}
// 将摘要转为字符串 返回
return byte2hex(byteArray);
}
/**
* 将二进制转化为16进制字符串
*
* @param b
* 二进制字节数组
* @return String
*/
public Stringbyte2hex(byte[]b){
Stringhs="";
Stringstmp="";
for (int i=0;i stmp=(java.lang.Integer.toHexString(b[i]&0XFF)); if (stmp.length()==1){ hs=hs+ "0" +stmp; } else { hs=hs+stmp; } } return hs.toUpperCase(); } public static void main(String[]args){ Stringmsg= "Hello"; System.out.println("明文是: " +msg); // 执行MD5加密"Hello" System.out.println("MD5加密了是: " + new MD5().encryptToMD5(msg)); //8B1A9953C4611296A827ABF8C47804D7 } } 2.DES package com.text; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; public class DES{ /** * 创建密匙 * * @param algorithm * 加密算法,可用 DES,DESede,Blowfish * @return SecretKey 秘密(对称)密钥 */ public SecretKeycreateSecretKey(Stringalgorithm){ // 声明KeyGenerator对象 KeyGeneratorkeygen; // 声明 密钥对象 SecretKeydeskey= null; try { // 返回生成指定算法的秘密密钥的 KeyGenerator 对象 keygen=KeyGenerator.getInstance(algorithm); // 生成一个密钥 deskey=keygen.generateKey(); } catch (NoSuchAlgorithmExceptione){ e.printStackTrace(); } // 返回密匙 return deskey; } /** * 根据密匙进行DES加密 * * @param key * 密匙 * @param info * 要加密的信息 * @return String 加密后的信息 */ public StringencryptToDES(SecretKeykey,Stringinfo){ // 定义 加密算法,可用 DES,DESede,Blowfish StringAlgorithm= "DES"; // 加密随机数生成器 (RNG),(可以不写) SecureRandomsr= new SecureRandom(); // 定义要生成的密文 byte[]cipherByte= null; try { // 得到加密/解密器 Cipherc1=Cipher.getInstance(Algorithm); // 用指定的密钥和模式初始化Cipher对象 // 参数: (ENCRYPT_MODE,DECRYPT_MODE,WRAP_MODE,UNWRAP_MODE) c1.init(Cipher.ENCRYPT_MODE,key,sr); // 对要加密的内容进行编码处理, cipherByte=c1.doFinal(info.getBytes()); } catch (Exceptione){ e.printStackTrace(); } // 返回密文的十六进制形式 return byte2hex(cipherByte); } /** * 根据密匙进行DES解密 * * @param key * 密匙 * @param sInfo * 要解密的密文 * @return String 返回解密后信息 */ public StringdecryptByDES(SecretKeykey,StringsInfo){ // 定义 加密算法, StringAlgorithm= "DES"; // 加密随机数生成器 (RNG) SecureRandomsr= new SecureRandom(); byte[]cipherByte= null; try { // 得到加密/解密器 Cipherc1=Cipher.getInstance(Algorithm); // 用指定的密钥和模式初始化Cipher对象 c1.init(Cipher.DECRYPT_MODE,key,sr); // 对要解密的内容进行编码处理 cipherByte=c1.doFinal(hex2byte(sInfo)); } catch (Exceptione){ e.printStackTrace(); } //returnbyte2hex(cipherByte); return new String(cipherByte); }
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Java Web几种加密算法 Web 加密算法