资源描述:
《java计算md5和sha1值》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、Java计算md5和sha1值计算数据md5和sha1值,防数据被其它人修改. 有时程序要求一些重要数据保密或加密的,如政府单位的公文归档的或盖章的,公文一般是盖了章就要不能修改的,为了防止修改数据,我给出自已的思路.1、在公文盖章完成的同时,将数据写入file里保存在磁盘中,可以将file内容加密保存。然后计算file内容的sha1值和md5值,将两个值保存起来。2、当用户打开盖好章的公文时,程序取出公文的数据(数据库里的数据)进行计算md5和sha1值,然后if在file里计算出来的md5和sha1值是不是相等,如果相等,那么数据库里的数据没有被修改过,如果发现值不相等时,表
2、示数据库里的数据被他人动过,那么这份公文应该提示无效或公章失效等。3、人工判断数据库的数据是否真的被动过,可以找出数据库的数据,和file的内容进行对比。注:这种做法不是绝对的,如果有更好的防数据修改的办法,欢迎一起探讨。以下给出的代码是计算md5和sha1值的计算方法。publicclassEncryptUtil{ publicStringtext=""; /** *@Description:使用MD5加密指定的字符串. *@params *@return *@date Aug12,2011 *@modify */ publicfinalstaticStringMD5(Str
3、ings){ charhexDigits[]={'0','1','2','3','4','5','6','7','8','9', 'a','b','c','d','e','f'}; try{ byte[]strTemp=s.getBytes(); MessageDigestmdTemp=MessageDigest.getInstance("MD5"); mdTemp.update(strTemp); byte[]md=mdTemp.digest(); intj=md.length; charstr[]=newchar[j*2]; intk=0;
4、 for(inti=0;i>>4&0xf]; str[k++]=hexDigits[byte0&0xf]; } returnnewString(str); }catch(Exceptionex){ thrownewRuntimeException(ex); } } /** *@Description:加密指定的整型数,通常用来加密ID值! *编码的原理是根据当前的currentTimeMillis在指定的位置插入其ID值,然后再附加 *ID值的
5、长度来进行编码.System.currentTimeMillis获取的值为13位长度,即使100 *年后也是这样,所以这个基本上是不变的! *@paramid *@return *@date Aug12,2011 *@modify */ privatefinalstaticintENCODE_ID_INSERT_INDEX=5;//插入的索引位置,0-12之间 publicfinalstaticStringencodeId(intid){ String_id=String.valueOf(id); if(id<0
6、
7、_id.length()>9) return"";
8、 StringBuilderbuf=newStringBuilder(); buf.append(System.currentTimeMillis()); for(inti=0;i<_id.length();i++){ buf.insert(ENCODE_ID_INSERT_INDEX,_id.charAt(i)); } buf.append(_id.length());//长度校验位 returnbuf.toString(); } /** *@Description:反编码ID后的字符串.
*注意,编码和解码的数字长度不能超过9位! *@paramstr *@
9、return *@date Aug12,2011 *@modify */ publicfinalstaticintunencodeId(Stringstr){ Stringtimes=System.currentTimeMillis()+""; if(str==null
10、
11、str.length()