Java中常用的加密算法应用MD5,SHA,RSA
来源:互联网 发布:阿里云服务器端口号 编辑:程序博客网 时间:2024/05/28 16:07
作者: , 出处:中国IT实验室, 责任编辑: 李春禹,
2007-11-15 14:45
1. MD5加密,常用于加密用户名密码,当用户验证时。} } 2. SHA加密,与MD5相似的用法,只是两者的算法不同。} } 3. RSA加密,RAS加密允许解密。常用于文本内容的加密。
1. MD5加密,常用于加密用户名密码,当用户验证时。
protected byte[] encrypt(byte[] obj) ...{
try ...{
MessageDigest md5 = MessageDigest.getInstance("MD5");
md5.update(obj);
return md5.digest();
} catch (NoSuchAlgorithmException e) ...{
e.printStackTrace();
}
} 2. SHA加密,与MD5相似的用法,只是两者的算法不同。
protected byte[] encrypt(byte[] obj) ...{
try ...{
MessageDigest sha = MessageDigest.getInstance("SHA");
sha.update(obj);
return sha.digest();
} catch (NoSuchAlgorithmException e) ...{
e.printStackTrace();
}
} 3. RSA加密,RAS加密允许解密。常用于文本内容的加密。
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.interfaces.RSAPrivateKey;
import java.security.interfaces.RSAPublicKey;
import javax.crypto.Cipher; /** *//**
* RSAEncrypt
*
* @author maqujun
* @see
*/
public class RSAEncrypt ...{
/** *//**
* Main method for RSAEncrypt.
* @param args
*/
public static void main(String[] args) ...{
try ...{
RSAEncrypt encrypt = new RSAEncrypt();
String encryptText = "encryptText";
KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA");
keyPairGen.initialize(1024);
KeyPair keyPair = keyPairGen.generateKeyPair();
// Generate keys
RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate();
RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic();
byte[] e = encrypt.encrypt(publicKey, encryptText.getBytes());
byte[] de = encrypt.decrypt(privateKey,e);
System.out.println(encrypt.bytesToString(e));
System.out.println(encrypt.bytesToString(de));
} catch (Exception e) ...{
e.printStackTrace();
}
}
/** *//**
* Change byte array to String.
* @return byte[]
*/
protected String bytesToString(byte[] encrytpByte) ...{
String result = "";
for (Byte bytes : encrytpByte) ...{
result += (char) bytes.intValue();
}
return result;
}
/** *//**
* Encrypt String.
* @return byte[]
*/
protected byte[] encrypt(RSAPublicKey publicKey, byte[] obj) ...{
if (publicKey != null) ...{
try ...{
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
return cipher.doFinal(obj);
} catch (Exception e) ...{
e.printStackTrace();
}
}
return null;
}
/** *//**
* Basic decrypt method
* @return byte[]
*/
protected byte[] decrypt(RSAPrivateKey privateKey, byte[] obj) ...{
if (privateKey != null) ...{
try ...{
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.DECRYPT_MODE, privateKey);
return cipher.doFinal(obj);
} catch (Exception e) ...{
e.printStackTrace();
}
}
return null;
}
}
- Java中常用的加密算法应用MD5,SHA,RSA
- Java中常用的加密算法应用MD5,SHA,RSA
- Java中常用的加密算法应用MD5,SHA,RSA
- Java中常用的加密算法应用MD5,SHA,RSA
- Java常用加密算法应用MD5,SHA,RSA
- Java常用加密算法应用MD5,SHA,RSA
- Java中常用的加密算法MD5,SHA,RSA
- JAVA 常用的加密算法之单向加密MD5和SHA
- 常用的加密算法MD5、SHA-1
- Java 常用加密算法(一)---单向加密算法(MD5/SHA)
- 常用加密算法的Java实现(一) ——单向加密算法MD5和SHA
- 常用加密算法的Java实现(一) ——单向加密算法MD5和SHA
- 常用加密算法的Java实现(一)——单向加密算法MD5和SHA
- 常用加密算法的Java实现(一) ——单向加密算法MD5和SHA
- 【转】asp.net下常用的加密算法MD5、SHA-1应用代码
- Nodejs 中常见的加密算法:MD5,RSA
- Java 中MD5 和SHA加密算法工具类
- 各种Java加密算法 MD5 SHA HMAC PBE RSA DES(转载)
- ALV 输出控制字体颜色 例程
- Windows CE下访问物理内存的一些方法!!
- 初来报到
- 大家好:)
- 编号的函数
- Java中常用的加密算法应用MD5,SHA,RSA
- MSSQL:MS SQL SERVER中出现服务器xxx上的MSDTC不可用的解决方法
- 清理被注入的数据库
- Linux内核和传统Unix内核的比较
- 浪曦视频在线的ASP.NET AJAX视频教程下载
- 实时更新异地数据库
- 远程摄像头
- redhat9下安装qt-4.3.x及qtopia-4.3.x
- 什么是CMS系统