首页 热点资讯 义务教育 高等教育 出国留学 考研考公

与md5 一样给用于数据库数据加密的 还有什么? 免费付费的都可以 最好有网址

发布网友 发布时间:2022-04-24 19:31

我来回答

2个回答

热心网友 时间:2023-10-08 18:52

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数据加密的,其实ASP中常用到的都是MD5,偶尔有人用哈希加密(SHA-1),其它的就更少人用了。不过恰好我这里有MD5和哈希加密的原文件,如果想用我可以给你传过去。

热心网友 时间:2023-10-08 18:53

DES加密,不是也可以么,这个是双向加密方式,而非md5的不可逆转加密方式

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com