• <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)論

            久久人人爽人人爽人人片av高请| 久久99精品久久久久久9蜜桃 | 亚洲国产精品综合久久网络| 99久久综合狠狠综合久久| 久久精品国产精品亚洲下载| 伊人久久大香线蕉综合热线| 久久精品毛片免费观看| 国产精品熟女福利久久AV| 久久无码高潮喷水| 99久久精品费精品国产一区二区 | 思思久久99热只有频精品66| 久久中文骚妇内射| 久久久久人妻一区精品| 91精品国产综合久久精品| 欧美激情精品久久久久久久| 久久久久久久97| 久久亚洲sm情趣捆绑调教 | 一本久久综合亚洲鲁鲁五月天| 国产亚洲精品自在久久| 欧美精品乱码99久久蜜桃| 91精品国产综合久久香蕉| 久久久精品人妻一区二区三区蜜桃 | 日韩久久无码免费毛片软件| .精品久久久麻豆国产精品| 少妇熟女久久综合网色欲| 国产成人无码精品久久久免费| 久久婷婷国产综合精品| 久久久久国产精品人妻| 国产亚洲美女精品久久久| 成人免费网站久久久| 久久综合九色综合网站| 久久人人爽人人爽人人片AV麻烦 | 要久久爱在线免费观看| 久久99精品免费一区二区| 一本伊大人香蕉久久网手机| 久久人人爽爽爽人久久久| 亚洲AV日韩AV天堂久久| 亚洲日本va中文字幕久久| 久久SE精品一区二区| 亚洲国产美女精品久久久久∴| 欧美精品国产综合久久|