• <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;
                
            //開始計(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 天下 閱讀(1456) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Win32Linux編程

            <2012年8月>
            2930311234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評(píng)論

            久久人人爽爽爽人久久久| 久久婷婷五月综合成人D啪| 国产精品久久久久久久久| 国产成人精品久久综合| 亚洲欧美国产日韩综合久久| 国产精品亚洲综合久久 | 久久99精品国产麻豆| 人妻少妇久久中文字幕一区二区| 亚洲午夜久久久影院伊人| 国产精品成人99久久久久91gav| 7777精品久久久大香线蕉| 久久精品国产一区二区电影| 国产成人精品免费久久久久| 亚洲国产精品成人久久蜜臀| 久久狠狠色狠狠色综合| 久久妇女高潮几次MBA| 久久天天日天天操综合伊人av| 9久久9久久精品| 亚洲va久久久噜噜噜久久狠狠| 久久久免费观成人影院| 久久精品国产91久久麻豆自制| 漂亮人妻被中出中文字幕久久| 久久国产精品免费一区二区三区| 久久久婷婷五月亚洲97号色| 国产精品久久久久蜜芽| 久久久久久A亚洲欧洲AV冫| 女人香蕉久久**毛片精品| 久久久亚洲欧洲日产国码aⅴ| 亚洲va久久久噜噜噜久久男同| 囯产极品美女高潮无套久久久 | 久久亚洲国产精品123区| 久久国产精品99国产精| 亚洲国产精品无码久久| 欧美一区二区三区久久综合 | 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 99久久人人爽亚洲精品美女| …久久精品99久久香蕉国产| 国产精品女同久久久久电影院 | 亚洲国产精品无码成人片久久| 精品国产青草久久久久福利| 久久WWW免费人成一看片|