已遷址

          已遷址http://www.cnblogs.com/live365wang/

            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            28 隨筆 :: 0 文章 :: 1 評(píng)論 :: 0 Trackbacks

          本文轉(zhuǎn)自:http://school.cfan.com.cn/pro/java/2007-06-11/1181531460d67777.shtml

           

          在各種應(yīng)用系統(tǒng)的開(kāi)發(fā)中,經(jīng)常需要存儲(chǔ)用戶信息,很多地方都要存儲(chǔ)用戶密碼,而將用戶密碼直接存儲(chǔ)在服務(wù)器上顯然是不安全的,本文簡(jiǎn)要介紹工作中常用的 MD5加密算法,希望能拋磚引玉。

          (一)消息摘要簡(jiǎn)介

              一個(gè)消息摘要就是一個(gè)數(shù)據(jù)塊的數(shù)字指紋。即對(duì)一個(gè)任意長(zhǎng)度的一個(gè)數(shù)據(jù)塊進(jìn)行計(jì)算,產(chǎn)生一個(gè)唯一指印(對(duì)于SHA1是產(chǎn)生一個(gè)20字節(jié)的二進(jìn)制數(shù)組)。消息摘要是一種與消息認(rèn)證碼結(jié)合使用以確保消息完整性的技術(shù)。主要使用單向散列函數(shù)算法,可用于檢驗(yàn)消息的完整性,和通過(guò)散列密碼直接以文本形式保存等,目前廣泛使用的算法有MD4、MD5、SHA-1.

              消息摘要有兩個(gè)基本屬性:

              兩個(gè)不同的報(bào)文難以生成相同的摘要難以對(duì)指定的摘要生成一個(gè)報(bào)文,而可以由該報(bào)文反推算出該指定的摘要代表:美國(guó)國(guó)家標(biāo)準(zhǔn)技術(shù)研究所的SHA1和麻省理工學(xué)院Ronald Rivest提出的MD5

          (二)對(duì)字符串進(jìn)行加密


           public String EncoderByMd5(String str) throws NoSuchAlgorithmException,

          UnsupportedEncodingException{
           //確定計(jì)算方法
                   MessageDigest md5=MessageDigest.getInstance("MD5");
                   BASE64Encoder base64en = new BASE64Encoder();
           //加密后的字符串
                   String newstr=base64en.encode(md5.digest(str.getBytes("utf-8")));
           return newstr;
           }

              調(diào)用函數(shù):String str="0123456789"

               System.out.println(EncoderByMd5(str));

              輸出:eB5eJF1ptWaXm4bijSPyxw==

          (三)驗(yàn)證密碼是否正確

              因?yàn)镸D5是基于消息摘要原理的,消息摘要的基本特征就是很難根據(jù)摘要推算出消息報(bào)文,因此要驗(yàn)證密碼是否正確,就必須對(duì)輸入密碼(消息報(bào)文)重新計(jì)算其摘要,和數(shù)據(jù)庫(kù)中存儲(chǔ)的摘要進(jìn)行對(duì)比(即數(shù)據(jù)庫(kù)中存儲(chǔ)的其實(shí)為用戶密碼的摘要),若兩個(gè)摘要相同,則說(shuō)明密碼正確,不同,則說(shuō)明密碼錯(cuò)誤。


           public boolean checkpassword(String newpasswd,String oldpasswd) throws NoSuchAlgorithmException,

          UnsupportedEncodingException{
           if(EncoderByMd5(newpasswd).equals(oldpasswd))
           return true;
           else
           return false;
           }

          posted on 2011-02-22 13:42 已遷址 閱讀(105) 評(píng)論(0)  編輯  收藏 所屬分類: Java
          主站蜘蛛池模板: 墨竹工卡县| 咸宁市| 宜章县| 临沧市| 巴塘县| 榆林市| 闸北区| 林州市| 长宁区| 万年县| 鹤峰县| 榆林市| 于田县| 敦化市| 重庆市| 六枝特区| 丹寨县| 新乐市| 西和县| 广灵县| 城固县| SHOW| 邻水| 竹溪县| 靖江市| 屯门区| 宁陕县| 连云港市| 黔南| 邓州市| 元朗区| 望江县| 时尚| 会昌县| 宁蒗| 彭泽县| 四川省| 拉萨市| 长阳| 西贡区| 香港 |