`

使用MD5对数据库密码进行加密的实例

阅读更多
package com.lxitedu.tools.generate;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

import com.dcivision.framework.Crypt;
import com.dcivision.framework.SystemParameterConstant;
import com.dcivision.framework.SystemParameterFactory;

/**
* suit the php
*
* @author Administrator
*
*/
public class MD5 {

  // 解密类: Crypt
  private final static String[] hexDigits = { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d",
      "e", "f"                           };

  public static void main(String[] args) throws Exception {
    getMD5EncryptedString("");
    String encrptedPwd = Crypt.encrypt("diaoer",
        SystemParameterFactory.getSystemParameter(SystemParameterConstant.CRYPTO_SALT));
    System.out.println(getMD5EncryptedString("diaoer"));
    System.out.println(encrptedPwd);
  }

  public static String getMD5EncryptedString(String sourceString) throws NoSuchAlgorithmException {
    // 加密后的字符串
    // 创建具有指定算法名称的信息摘要
    MessageDigest md = MessageDigest.getInstance("MD5");
    // 使用指定的字节数组对摘要进行最后更新,然后完成摘要计算
    byte[] results = md.digest(sourceString.getBytes());
    return byteArrayToHexString(results);
  }

  private static String byteArrayToHexString(byte[] b) {
    StringBuffer resultSb = new StringBuffer();
    for (int i = 0; i < b.length; i++) {
      resultSb.append(byteToHexString(b[i]));
    }
    return resultSb.toString();
  }

  /**
   * 将一个字节转化成十六进制形式的字符串
   */
  private static String byteToHexString(byte b) {
    int n = b;
    if (n < 0)
      n = 256 + n;
    int d1 = n / 16;
    int d2 = n % 16;
    return hexDigits[d1] + hexDigits[d2];
  }

}





解密:
/*
* @(#)Crypt.java
*
* Copyright (c) 2003 DCIVision Ltd
* All rights reserved.
*
* This software is the confidential and proprietary information of DCIVision
* Ltd ("Confidential Information").  You shall not disclose such Confidential
* Information and shall use it only in accordance with the terms of the license
* agreement you entered into with DCIVision Ltd.
*/
package com.dcivision.framework;

/**
* Crypt.java
*
* This class is to provide encrypt and decrypt function by a password provided.
*
* @author Rollo Chan
* @company DCIVision Limited
* @creation date 25/06/2003
* @version $Revision: 1.6 $
*/

public class Crypt {

  public static final String REVISION = "$Revision: 1.6 $";

  private Crypt() {
  }

  /**
   * encrypt
   *
   * Encrypt a string with a password
   *
   * @param buffer
   *          The buffer to be encrypted
   * @param password
   *          The password
   */
  public static String encrypt(String buffer, String password) {
    StringBuffer sbSpace = new StringBuffer("     ");
    buffer = sbSpace.toString() + buffer + sbSpace.toString();
    char[] temp = new char[buffer.length()];

    int a = 0;
    for (int i = 0; i < buffer.length(); i++) {
      int b = password.charAt(a);
      a++;
      if (a >= password.length()) {
        a = 0;
      }
      int c = (int) buffer.charAt(i);
      temp[i] = (char) (c ^ b);
    }
    return toHex(temp);
  }

  /**
   * decrypt
   *
   * Decrypt a string with a password
   *
   * @param buffer
   *          The buffer to be decrypted
   * @param password
   *          The password
   */
  public static String decrypt(String buffer, String password) {
    char[] temp = toChar(buffer);
    String result = "";
    int a = 0;
    for (int i = 0; i < temp.length; i++) {
      int b = password.charAt(a);
      a++;
      if (a >= password.length()) {
        a = 0;
      }
      int c = temp[i];
      result += (char) (c ^ b);// ^ 按位异或XOR 就是二个操作数只有一个是1的话结果就是 1 否则就是 0 。
    }
    return result.trim();
  }

  private static int hexToInt(char c) {
    if (c >= '0' && c <= '9') {
      return c - '0';
    }
    return (c - 'a') + 10;
  }

  private static char hexToChar(String buffer) {
    int l = hexToInt(buffer.charAt(1));
    int h = hexToInt(buffer.charAt(0));
    return (char) (h * 16 + l);
  }

  private static String toHex(char[] buffer) {
    String temp = "";
    String result = "";
    for (int i = 0; i < buffer.length; i++) {
      int c = buffer[i];
      temp = Integer.toHexString((int) c);
      if (temp.length() == 1) {
        temp = "0" + temp;
      }
      result += temp;
    }
    return result;
  }

  private static char[] toChar(String buffer) {
    char[] result = new char[buffer.length() / 2];
    for (int i = 0; i < buffer.length(); i += 2) {
      if (i + 2 <= buffer.length()) {
        String temp = buffer.substring(i, i + 2);
        result[i / 2] = (char) hexToChar(temp);
      }
    }
    return result;
  }

  /**
   * main
   *
   * @param arg
   */
  public static void main(String arg[]) {
    // String buffer = arg[0];
    // String password = arg[1];
    String buffer = "diaoer";
    String password = "test";
    String temp = Crypt.encrypt(buffer, password);
    System.out.println("buffer    = \"" + buffer + "\"");
    System.out.println("password  = \"" + password + "\"");
    System.out.println("encrypted = \"" + temp + "\"");
    System.out.println("decrypted = \"" + Crypt.decrypt(temp, password) + "\"");
  }
}
分享到:
评论

相关推荐

    Java MD5 加密数据库连接池密码

    具体的解密过程取决于加密策略,如果只是简单地MD5加密,那么通常不会解密,而是直接在连接池中使用加密后的密码连接数据库。 在给定的文件`hibernateExample1`中,可能包含了一个使用Hibernate框架的示例,...

    md5加密数据库

    总结起来,这个"md5加密数据库"项目是一个教育性的编程示例,展示了如何在VB和C#环境中使用MD5算法对数据库中的密码进行加密,以增强数据安全性。它对于初学者理解加密原理和.NET框架下的加密操作非常有帮助。然而,...

    在java中使用MD5进行密码加密

    ### 在Java中使用MD5进行密码加密 #### 知识点概述 在现代软件开发过程中,安全性至关重要。尤其是在处理敏感信息如用户密码时,确保数据的安全性和隐私性尤为重要。MD5(Message-Digest Algorithm 5)是一种广泛...

    普遍用到的MD5加密实例

    但要注意,尽管单向性使得MD5在理论上是安全的,但由于彩虹表的存在,一些常见的密码可以通过预先计算的哈希值进行反查,因此现在MD5已经不再被视为足够安全的密码加密方式,更安全的哈希算法如SHA-256被更多采用。...

    VC++ MD5 加 数据库密码存储!

    在这个例子中,开发者使用ADO进行数据库操作,比如存储经过MD5哈希处理的密码。虽然描述中提到代码没有使用try...catch错误处理结构,这是一种最佳实践,用于捕获和处理运行时可能出现的异常,确保程序的稳定性和...

    asp.net 密码加密实例

    本文将详细讲解如何在ASP.NET中实现密码的加密,以确保数据的安全性,特别是采用MD5算法进行密码哈希加密的实例。 一、MD5概述 MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希函数,它能够将任意长度的...

    MD5加密实例(加盐)

    5. **验证密码**:在用户登录时,获取输入的密码,结合存储的盐重新进行MD5加盐哈希,然后与数据库中存储的哈希值进行比较。如果两者匹配,则验证成功。 MD5加盐相对于未加盐的MD5提高了安全性,但需要注意的是,...

    servlet中md5加密

    在实际应用中,可以通过创建`Md5Encrypt`类的实例并调用其`Encrypt`方法来对字符串进行MD5加密。 ```java Md5Encrypt md = new Md5Encrypt(); String password = "your_password"; String encryptedPassword = md....

    MD5加密代码以及使用实例

    通常,当用户输入密码时,系统会计算输入的密码的MD5哈希值,然后与数据库中存储的已哈希的密码进行比较。如果两者匹配,则认为密码正确。这种方式避免了明文密码的直接存储,增加了安全性。但需要注意的是,MD5的...

    HTML实现基于MD5加密的登录注册界面源码

    在登录注册系统中,MD5通常用于对用户输入的密码进行加密处理,使得即使数据库被泄露,原始密码也无法直接获取,提高了安全性。 在登录界面,用户输入用户名和密码后,后台程序会接收到这些数据。在存储之前,密码...

    md5加密实例,值得您学习

    在MD5加密实例中,我们通常会遇到以下几个关键知识点: 1. **MD5原理**:MD5算法基于消息的分块处理和一系列复杂的数学运算,包括异或、位移和加法等,确保即使是微小的数据变化也会导致生成的哈希值显著不同,实现...

    MD5密码加密技术.zip

    这段代码展示了如何在Java中使用MD5对字符串进行加密。首先,我们创建了一个`MessageDigest`实例,指定使用MD5算法。然后,将要加密的字符串转换为字节数组并传递给`digest()`方法。得到的哈希值是一组字节,我们将...

    Winform中简单使用MD5加密用户登录密码示例代码.zip

    本示例代码聚焦于如何在WinForm应用程序中使用MD5(Message-Digest Algorithm 5)算法对用户登录密码进行加密,确保数据的安全性。 MD5是一种广泛使用的哈希函数,能够将任意长度的信息映射为固定长度的输出,通常...

    MD5算法的ASP实现,MD5简介,MD5加密解密vb工程

    通常,我们会将用户密码通过MD5加密后存储在数据库中,当用户输入密码时,再进行MD5加密并与数据库中的值比较,以验证密码的正确性。 在提供的压缩包文件中,"MD5.doc"可能是关于MD5算法的详细文档,涵盖了MD5的...

    数据库账号密码加密详解及实例

    在上述示例中,自定义的`MyPasswordEncoder`类扩展了`MessageDigestPasswordEncoder`,并重写了`isPasswordValid`方法,以使用MD5算法进行密码验证。 Spring Security的配置文件中,`&lt;password-encoder&gt;`元素用于...

    MD5加密例子

    当用户注册时,其密码不会直接存储,而是先通过MD5算法加密成摘要,然后在用户登录时,系统同样对输入的密码进行MD5加密,比较两个摘要是否相同来验证密码是否正确。这样即使数据库被泄露,攻击者也无法直接获取到...

    MD5加密调用 数据库存加密数据

    在实际操作中,我们通常会先对用户输入的明文密码进行MD5加密,然后将得到的MD5摘要存入数据库。例如,`RegisterSQL`可能是一个包含用户注册信息的SQL脚本,其中就包括了将MD5加密后的密码写入数据库的语句。以下是...

    JAVA加密MD5源代码

    MD5(Message-Digest Algorithm 5)是一种广泛使用的密码散列函数,能够将任意长度的消息压缩为一个固定长度(通常是128位)的散列值或指纹。这种算法在数据完整性验证、密码存储等方面有着广泛的应用。 ### MD5...

    ASP.net中md5加密码的方法

    在提供的代码示例中,展示了如何在ASP.NET中使用MD5对字符串进行加密,分为两种方式:普通加密和密码方式加密。 1. **普通加密**: 在`Page_Load`事件处理程序中,首先获取`source.Text`的Unicode编码形式的字节...

    java中使用MD5加密算法进行加密.pdf

    当用户登录时,我们再次对用户输入的密码进行MD5加密,然后与数据库中存储的摘要进行比较。如果两者相等,那么就认为密码正确;否则,密码错误。这样做的好处是即使数据库被泄露,攻击者也无法直接获得用户的原始...

Global site tag (gtag.js) - Google Analytics