1、加密是单向的,也就是说很容易将数据加密,但是却不容易解密。
2、相同的数据加密后得到的密文一样。相同的密文解密后,得到的数据也一样。    
3、一般是把密码加密。将密文存于数据库中。
      在以后的相关操作中,每次比较密码是否相同时,先将已给的密码加密,再将它与数据库中的密文比较,密文相同则对应的密码一样 。


利用java加密过程如下:

编程思路:Java.security包中的MessageDigest类提供了计算消息摘要的方法, 首先生成对象,执行其update( )方法可

以将原始数据传递给该对象,然后执行其digest( )方法即可得到消息摘要。具体步骤如下:

(1)生成MessageDigest对象

MessageDigest m=MessageDigest.getInstance("MD5");

分析:和2.2.1小节的KeyGenerator类一样。MessageDigest类也是一个工厂类,其构造器是受保护的,不允许

直接使用new MessageDigist( )来创建对象,而必须通过其静态方法getInstance( )生成MessageDigest对象。

其中传入的参数指定计算消息摘要所使用的算法,常用的有"MD5","SHA"等。若对MD5算法的细节感兴趣可参考

http://www.ietf.org/rfc/rfc1321.txt。

(2)传入需要计算的字符串

m.update(x.getBytes("UTF8" ));

分析:x为需要计算的字符串,update传入的参数是字节类型或字节类型数组,对于字符串,需要先使用

getBytes( )方法生成字符串数组。

(3)计算消息摘要

byte s[ ]=m.digest( );

分析:执行MessageDigest对象的digest( )方法完成计算,计算的结果通过字节类型的数组返回。

(4)处理计算结果

必要的话可以使用如下代码将计算结果s转换为字符串。

String result="";

for (int i=0; i

result+=Integer.toHexString((0x000000ff & s[i]) 0xffffff00).substring(6);

}

★代码与分析:

编程思路:Java.security包中的MessageDigest类提供了计算消息摘要的方法, 首先生成对象,执行其update( )方法可

以将原始数据传递给该对象,然后执行其digest( )方法即可得到消息摘要。具体步骤如下:

(1)生成MessageDigest对象

MessageDigest m=MessageDigest.getInstance("MD5");

分析:和2.2.1小节的KeyGenerator类一样。MessageDigest类也是一个工厂类,其构造器是受保护的,不允许

直接使用new MessageDigist( )来创建对象,而必须通过其静态方法getInstance( )生成MessageDigest对象。

其中传入的参数指定计算消息摘要所使用的算法,常用的有"MD5","SHA"等。若对MD5算法的细节感兴趣可参考

http://www.ietf.org/rfc/rfc1321.txt。

(2)传入需要计算的字符串

m.update(x.getBytes("UTF8" ));

分析:x为需要计算的字符串,update传入的参数是字节类型或字节类型数组,对于字符串,需要先使用

getBytes( )方法生成字符串数组。

(3)计算消息摘要

byte s[ ]=m.digest( );

分析:执行MessageDigest对象的digest( )方法完成计算,计算的结果通过字节类型的数组返回。

(4)处理计算结果

必要的话可以使用如下代码将计算结果s转换为字符串。

String result="";

for (int i=0; i

result+=Integer.toHexString((0x000000ff & s[i]) 0xffffff00).substring(6);

}

★代码与分析: 

完整程序如下:

import java.security.*;

public class DigestPass{

public static void main(String args[ ]) throws Exception{

String x=args[0];

MessageDigest m=MessageDigest.getInstance("MD5");

m.update(x.getBytes("UTF8"));

byte s[ ]=m.digest( );

String result="";

for (int i=0; i

result+=Integer.toHexString((0x000000ff & s[i]) 0xffffff00).substring(6);

}

System.out.println(result);

}

}

★运行程序

 

输入java DigestCalc abc来运行程序,其中命令行参数abc是原始数据,屏幕输出计算后的消息摘要:

900150983cd24fb0d6963f7d28e17f72。


某具体应用程序的写法:
package org.base.utility.security;


import java.security.*;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

public class Encrypter {

  private final static Log logger = LogFactory.getLog(Encrypter.class);

  /**
   * 非对称MD5加密方法
   *
   * @param data
   *          需要加密的数据
   * @return 加密后的数据
   */
  public synchronized static final String hashByMD5(String data) {
    try {
      MessageDigest digest = MessageDigest.getInstance("MD5");
      digest.update(data.getBytes());
      return encodeHex(digest.digest());
    } catch (NoSuchAlgorithmException nsae) {
      logger.error("Failed to load the MD5 MessageDigest. "
          + "will be unable to function normally.");
      nsae.printStackTrace();
      return null;
    }
  }

  private static final String encodeHex(byte[] bytes) {

    StringBuffer buf = new StringBuffer(bytes.length * 2);
    for (int i = 0; i < bytes.length; i++) {
      if (((int) bytes[i] & 0xff) < 0x10) {
        buf.append("0");
      }
      buf.append(Long.toString((int) bytes[i] & 0xff, 16));
    }
    return buf.toString();
  }
}




标题  
姓名  
主页
验证码 *  
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
 
 
相关链接:
网站导航:



posts - 4, comments - 8, trackbacks - 0, articles - 18

Copyright © 黎素智