• <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 天下 閱讀(1456) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): Win32 、Linux編程

            <2013年6月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(4)

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

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評(píng)論

            久久人人爽人人爽人人爽| 国内精品久久久久久中文字幕| 99久久无码一区人妻| 久久久久九国产精品| 久久97精品久久久久久久不卡| 99久久精品费精品国产一区二区| 66精品综合久久久久久久| 久久精品这里只有精99品| 伊人久久大香线蕉亚洲五月天| 精品久久久久久亚洲精品| 国产免费久久久久久无码| 久久伊人五月天论坛| 久久青草国产精品一区| 成人久久精品一区二区三区| 久久综合成人网| 情人伊人久久综合亚洲| 99久久这里只有精品| 久久国产色AV免费观看| 国产一区二区三精品久久久无广告| 亚洲人AV永久一区二区三区久久| 国产精品18久久久久久vr | 欧美牲交A欧牲交aⅴ久久| 久久亚洲2019中文字幕| 久久黄色视频| 精品99久久aaa一级毛片| 91亚洲国产成人久久精品网址| 久久青草国产手机看片福利盒子| 无码日韩人妻精品久久蜜桃| 精品综合久久久久久97| 99蜜桃臀久久久欧美精品网站| 久久只有这里有精品4| 久久笫一福利免费导航 | 99久久精品费精品国产一区二区| 性欧美大战久久久久久久久 | 久久久久亚洲?V成人无码| 久久夜色精品国产亚洲av| 久久中文娱乐网| 久久精品国产2020| 久久国产高清一区二区三区| 91麻豆国产精品91久久久| 久久精品中文无码资源站|