免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1551 | 回复: 0
打印 上一主题 下一主题

Java中常用的加密算法应用 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-12-05 09:27 |只看该作者 |倒序浏览

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;
  }
  }


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/13830/showart_2111664.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP