在JSP中如何实现MD5加密的方法.docx

上传人:b****6 文档编号:3193023 上传时间:2022-11-19 格式:DOCX 页数:15 大小:20.86KB
下载 相关 举报
在JSP中如何实现MD5加密的方法.docx_第1页
第1页 / 共15页
在JSP中如何实现MD5加密的方法.docx_第2页
第2页 / 共15页
在JSP中如何实现MD5加密的方法.docx_第3页
第3页 / 共15页
在JSP中如何实现MD5加密的方法.docx_第4页
第4页 / 共15页
在JSP中如何实现MD5加密的方法.docx_第5页
第5页 / 共15页
点击查看更多>>
下载资源
资源描述

在JSP中如何实现MD5加密的方法.docx

《在JSP中如何实现MD5加密的方法.docx》由会员分享,可在线阅读,更多相关《在JSP中如何实现MD5加密的方法.docx(15页珍藏版)》请在冰豆网上搜索。

在JSP中如何实现MD5加密的方法.docx

在JSP中如何实现MD5加密的方法

在JSP中如何实现MD5加密的方法

这篇文章主要介绍了在JSP中如何实现MD5加密的方法,较为详细的分析了JSP采用MD5加密的功能、特点及实现技巧,具有一定参考借鉴价值,

在各种应用系统的开发中,经常需要存储用户信息,很多地方都要存储用户密码,而将用户密码直接存储在服务器上显然是不安全的,本文简要介绍在JSP中如何实现MD5加密的方法,希望能抛砖引玉。

 

(一)消息摘要简介

一个消息摘要就是一个数据块的数字指纹。

即对一个任意长度的一个数据块进行计算,产生一个唯一指印(对于SHA1是产生一个20字节的二进制数组)。

消息摘要是一种与消息认证码结合使用以确保消息完整性的技术。

主要使用单向散列函数算法,可用于检验消息的完整性,和通过散列密码直接以文本形式保存等,目前广泛使用的算法有MD4、MD5、SHA-1。

消息摘要有两个基本属性:

 

两个不同的报文难以生成相同的摘要

 

难以对指定的摘要生成一个报文,而可以由该报文反推算出该指定的摘要。

 

Java源码

importjava.security.MessageDigest;

importjava.security.NoSuchAlgorithmException;

publicclassMD5Digest

{

privateMessageDigest__md5=null;

privateStringBuffer__digestBuffer=null;

publicMD5Digest()

throwsNoSuchAlgorithmException

{

__md5=MessageDigest.getInstance("MD5");

__digestBuffer=newStringBuffer();

}

publicStringmd5crypt(Strings)

{

__digestBuffer.setLength(0);

byteabyte0[]=__md5.digest(s.getBytes());

for(inti=0;i

__digestBuffer.append(toHex(abyte0[i]));

return__digestBuffer.toString();

}

publicStringtoHex(byteone){

StringHEX="0123456789ABCDEF";

char[]result=newchar[2];

result[0]=HEX.charAt((one&0xf0)>>4);

result[1]=HEX.charAt(one&0x0f);

Stringmm=newString(result);

returnmm;

}

}

/************************************************

  MD5算法的JavaBean

  @author:

TopcatTuppin

  LastModified:

10,Mar,2001

  *************************************************/

  packagebeartool;

  importjava.lang.reflect.*;

  /*************************************************

  md5类实现了RSADataSecurity,Inc.在提交给IETF

  的RFC1321中的MD5message-digest算法。

  *************************************************/

  publicclassMD5{

  /*下面这些S11-S44实际上是一个4*4的矩阵,在原始的C实现中是用#define实现的,

  这里把它们实现成为staticfinal是表示了只读,切能在同一个进程空间内的多个

  Instance间共享*/

  staticfinalintS11=7;

  staticfinalintS12=12;

  staticfinalintS13=17;

  staticfinalintS14=22;

  staticfinalintS21=5;

  staticfinalintS22=9;

  staticfinalintS23=14;

  staticfinalintS24=20;

  staticfinalintS31=4;

  staticfinalintS32=11;

  staticfinalintS33=16;

  staticfinalintS34=23;

  staticfinalintS41=6;

  staticfinalintS42=10;

  staticfinalintS43=15;

  staticfinalintS44=21;

  staticfinalbyte[]PADDING={-128,0,0,0,0,0,0,0,0,

  0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,

  0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,

  0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};

  /*下面的三个成员是MD5计算过程中用到的3个核心数据,在原始的C实现中

  被定义到MD5_CTX结构中

  */

  privatelong[]state=newlong[4];//state(ABCD)

  privatelong[]count=newlong[2];//numberofbits,modulo2^64(lsbfirst)

  privatebyte[]buffer=newbyte[64];//inputbuffer

  /*digestHexStr是MD5的唯一一个公共成员,是最新一次计算结果的

   16进制ASCII表示.

  */

  publicStringdigestHexStr;

  /*digest,是最新一次计算结果的2进制内部表示,表示128bit的MD5值.

  */

  privatebyte[]digest=newbyte[16];

  /*

  getMD5ofStr是类MD5最主要的公共方法,入口参数是你想要进行MD5变换的字符串

  返回的是变换完的结果,这个结果是从公共成员digestHexStr取得的.

  */

  publicStringgetMD5ofStr(Stringinbuf){

  md5Init();

  md5Update(inbuf.getBytes(),inbuf.length());

  md5Final();

  digestHexStr="";

  for(inti=0;i<16;i++){

  digestHexStr+=byteHEX(digest[i]);

  }

  returndigestHexStr;

  }

  //这是MD5这个类的标准构造函数,JavaBean要求有一个public的并且没有参数的构造函数

  publicMD5(){

  md5Init();

  return;

  }

  /*md5Init是一个初始化函数,初始化核心变量,装入标准的幻数*/

  privatevoidmd5Init(){

  count[0]=0L;

  count[1]=0L;

  ///*Loadmagicinitializationconstants.

  state[0]=0x67452301L;

  state[1]=0xefcdab89L;

  state[2]=0x98badcfeL;

  state[3]=0x10325476L;

  return;

  }

  /*F,G,H,I是4个基本的MD5函数,在原始的MD5的C实现中,由于它们是

  简单的位运算,可能出于效率的考虑把它们实现成了宏,在java中,我们把它们

    实现成了private方法,名字保持了原来C中的。

*/

  privatelongF(longx,longy,longz){

  return(x&y)|((~x)&z);

  }

  privatelongG(longx,longy,longz){

  return(x&z)|(y&(~z));

  }

  privatelongH(longx,longy,longz){

  returnx^y^z;

  }

  privatelongI(longx,longy,longz){

  returny^(x|(~z));

  }

  /*

  FF,GG,HH和II将调用F,G,H,I进行近一步变换

  FF,GG,HH,andIItransformationsforrounds1,2,3,and4.

  Rotationisseparatefromadditiontopreventrecomputation.

  */

  privatelongFF(longa,longb,longc,longd,longx,longs,

  longac){

  a+=F(b,c,d)+x+ac;

  a=((int)a<>>(32-s));

  a+=b;

  returna;

  }

  privatelongGG(longa,longb,longc,longd,longx,longs,

  longac){

  a+=G(b,c,d)+x+ac;

  a=((int)a<>>(32-s));

  a+=b;

  returna;

  }

  privatelongHH(longa,longb,longc,longd,longx,longs,

  longac){

  a+=H(b,c,d)+x+ac;

  a=((int)a<>>(32-s));

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 解决方案 > 其它

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1