• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天下

            記錄修行的印記

            單文件版SHA1函數(shù)

            //SHA1.cpp
            #include <string>




            std::
            string SHA1(std::string s)
            {
                
            const char HEX_CHAR[]={'0''1''2''3''4''5''6''7',
                    
            '8''9''a''b''c''d''e''f'};
                
            const unsigned long K[] = {0x5A8279990x6ED9EBA10x8F1BBCDC0xCA62C1D6};
                
            //擴(kuò)展成K*512位
                unsigned long *data;
                
            int l;
                l 
            = s.length()*8;
                data 
            = new unsigned long[((l/512)+1)*512];
                memset(data, 
            0sizeof(data[0])*((l/512)+1)*512);
                
            for(unsigned int i = 0; i < s.length(); ++i){
                    data[i 
            / 4|= s[i] << 8*(3 - (i % 4));
                }
                data[s.length() 
            / 4|= 0x80 << 8*(3-(s.length()%4));
                data[((l
            /512)+1)*512/32-1]=l;
                l 
            = (l/512)+1;
                
            //開(kāi)始計(jì)算
                unsigned long H[5], G[5];
                H[
            0= G[0= 0x67452301;
                H[
            1= G[1= 0xEFCDAB89;
                H[
            2= G[2= 0x98BADCFE;
                H[
            3= G[3= 0x10325476;
                H[
            4= G[4= 0xC3D2E1F0;
                
            for(int i = 0; i<l; ++i){
                    unsigned 
            long W[80];
                    
            int t;
                    
            for(t = 0; t<16++t)
                        W[t] 
            = data[i*16+t];
                    
            for(t = 16; t<80++t){
                        unsigned 
            long tmp = W[t-3^ W[t-8^ W[t-14^ W[t-16];
                        W[t] 
            = (tmp << 1)|(tmp >> 31);
                    }
                    unsigned 
            long tmp;
                    
            for(t = 0; t<5++t)
                        H[t] 
            = G[t];
                    
            for(t = 0; t<20++t){
                        tmp 
            = ((H[0<< 5| (H[0>> 27)) + ((H[1& H[2]) | (~ H[1& H[3])) + H[4+ W[t] + K[0];
                        H[
            4= H[3]; H[3= H[2]; H[2= (H[1]<<30)|(H[1>> 2); H[1= H[0]; H[0= tmp;
                    }
                    
            for(t = 20; t<40++t){
                        tmp 
            = ((H[0<< 5| (H[0>> 27)) + (H[1^ H[2^ H[3]) + H[4+ W[t] + K[1];
                        H[
            4= H[3]; H[3= H[2]; H[2= (H[1]<<30)|(H[1>> 2); H[1= H[0]; H[0= tmp;
                    }
                    
            for(t = 40; t<60++t){
                        tmp 
            = ((H[0<< 5| (H[0>> 27)) + ((H[1& H[2])|(H[2& H[3])|(H[1& H[3])) + H[4+ W[t] + K[2];
                        H[
            4= H[3]; H[3= H[2]; H[2= (H[1]<<30)|(H[1>> 2); H[1= H[0]; H[0= tmp;
                    }
                    
            for(t = 60; t<80++t){
                        tmp 
            = ((H[0<< 5| (H[0>> 27)) + (H[1^ H[2^ H[3]) + H[4+ W[t] + K[3];
                        H[
            4= H[3]; H[3= H[2]; H[2= (H[1]<<30)|(H[1>> 2); H[1= H[0]; H[0= tmp;
                    }
                    
            for(t = 0; t<5++t)
                        G[t] 
            += H[t];
                }
                delete data;
                
            char buf[41];
                
            for(int i = 0; i<40++i){
                    buf[i] 
            = HEX_CHAR[(G[i / 8>> (4*(7- (i % 8))))&0xf];
                }
                buf[
            40= '\0';
                
            return std::string(buf);
            }


            //Test
            //#include <iostream>
            //using namespace std;
            //int main(int argc, char* argv[])
            //{
            //    char s[100];
            //    while(true){
            //        scanf("%s", s);
            //        cout <<  SHA1(s)<< endl;
            //    }
            //    return 0;
            //}

            posted on 2012-01-12 17:04 天下 閱讀(1444) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): Win32Linux編程

            <2013年4月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(4)

            隨筆分類(lèi)(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評(píng)論

            国产精品久久久久久搜索| 亚洲精品国产字幕久久不卡| 久久精品99无色码中文字幕| 国产综合成人久久大片91| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 亚洲国产精品久久久天堂| 久久久久免费看成人影片| 亚洲国产精品久久| 蜜桃麻豆WWW久久囤产精品| 久久精品www人人爽人人| 99久久精品免费看国产| 久久久一本精品99久久精品88| 99久久无色码中文字幕| 亚洲精品美女久久久久99小说 | 久久五月精品中文字幕| 久久99久久99精品免视看动漫 | 亚洲日本久久久午夜精品| 国产亚洲综合久久系列| 性高湖久久久久久久久AAAAA| 久久大香香蕉国产| 香港aa三级久久三级老师2021国产三级精品三级在 | 麻豆AV一区二区三区久久| 国产精品内射久久久久欢欢| 久久久久波多野结衣高潮| 一本一道久久精品综合| A级毛片无码久久精品免费| 国产高潮久久免费观看| 亚洲熟妇无码另类久久久| 精品国产一区二区三区久久蜜臀| 老色鬼久久亚洲AV综合| 伊人久久大香线蕉无码麻豆 | 亚洲级αV无码毛片久久精品| 久久AAAA片一区二区| 国产一区二区三区久久| 性欧美丰满熟妇XXXX性久久久 | 狠狠综合久久综合中文88 | 久久人搡人人玩人妻精品首页| 国产精品久久久亚洲| 亚洲中文字幕无码久久2020| 久久久久人妻精品一区三寸蜜桃| 久久91精品国产91久久户|