加密 总结

heliit 2011-11-15 10:58:24
/**
* MD5加密
*
* @param pwd
* 传入的密码字符串
* @return 加密后的密码
* @see [类、类#方法、类#成员]
*/
public static String getMD5pwd(String pwd) {
StringBuffer code = new StringBuffer("");
try {
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(pwd.getBytes());
byte[] bt = md.digest();
int j;
for (int i = 0; i < bt.length; i++) {
j = bt[i];
if (j < 0) {
j += 256;
}
if (j < 16) {
code.append("0");
}
code.append(Integer.toHexString(j));
}
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return code.toString();
}

/**
* 获取系统密钥
* @return 系统默认密钥
* @see [类、类#方法、类#成员]
*/
public static String getSystemKey(){
SysConfigManager sysConfigManager = DBGroup.getInstance().getVGroup().getSystemGroup().getSysConfigManager();
SysConfig key_sysConfig = sysConfigManager.findSysConfigByCode("system_key");
return key_sysConfig.getConfigValue();
}

/**
* Des解密
*
* @param pwd
* 密码
* @return 解密后的密码
* @see [类、类#方法、类#成员]
*/
public static String DesDecode(String pwd,String desSceret) {
// 为我们选择的DES算法生成一个KeyGenerator对象
try {
Key key = init("DESede",desSceret);
Cipher cipher = Cipher.getInstance("DESede");
// 解密
cipher.init(Cipher.DECRYPT_MODE, key);
byte[] tt = cipher.doFinal(hex2byte(pwd));
String code = new String(tt);
return code;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}

/**
* 创建密匙
* @param algorithm 加密算法,可用 DES,DESede,Blowfish
* @param desSceret 加密密钥,要求转换为UTF-8的格式,字节长度至少24位
* @return 秘密(对称)密钥
* @see [类、类#方法、类#成员]
*/
private static Key init(String algorithm, String desSceret) {
Key key = null;
try {
DESedeKeySpec dks = new DESedeKeySpec(desSceret
.getBytes("UTF-8"));
SecretKeyFactory keyFactory = SecretKeyFactory
.getInstance(algorithm);
key = keyFactory.generateSecret(dks);
} catch (Exception e) {
e.printStackTrace();
}
return key;
}
...全文
85 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
alike188 2011-11-16
  • 打赏
  • 举报
回复
还行吧,你如果要深入需要学习信息安全的课程,公元前古罗马人就开始做加解密了。
LPZLSDJF 2011-11-15
  • 打赏
  • 举报
回复
又掌握了一种方法 呵呵~

67,512

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧