• <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函數

            //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};
                
            //擴展成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;
                
            //開始計算
                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) 評論(0)  編輯 收藏 引用 所屬分類: Win32Linux編程

            <2012年5月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            久久久久久毛片免费播放| 久久涩综合| 久久精品国产精品青草| 狠狠色丁香久久婷婷综| 久久婷婷五月综合色99啪ak| 久久综合亚洲鲁鲁五月天| 久久久久99精品成人片试看| 99久久精品无码一区二区毛片 | 99久久综合国产精品免费| 一本一本久久A久久综合精品| 99久久精品影院老鸭窝| 性做久久久久久久久老女人| 久久国产精品成人片免费| 久久精品无码一区二区三区免费 | 中文字幕无码免费久久| 岛国搬运www久久| AV无码久久久久不卡网站下载| 久久久久久久综合日本亚洲| 7777精品伊人久久久大香线蕉| 亚洲精品高清久久| 精品久久久久久亚洲精品| 亚洲精品乱码久久久久久不卡| 亚洲国产二区三区久久| 国产国产成人精品久久| 亚洲国产一成人久久精品| 2021最新久久久视精品爱| 久久精品国产99国产精品| 亚洲国产成人久久综合碰碰动漫3d | 国产精品伊人久久伊人电影| 久久人人妻人人爽人人爽| 日日躁夜夜躁狠狠久久AV| 国产精品久久婷婷六月丁香| 久久久精品人妻无码专区不卡| 国产国产成人久久精品| 久久久中文字幕| 欧美一区二区精品久久| 国产成人精品久久| 99久久夜色精品国产网站| 久久无码高潮喷水| 久久这里都是精品| 久久久久久久久久久|