亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? des.c

?? smartcard的des程序 加密方面的內容
?? C
?? 第 1 頁 / 共 2 頁
字號:
tform1( 59, 51, 43, 35, 27, 19, 11,  3)tform2( 60, 52, 44, 36,  1,  1,  1,  1)
0xFF,
/* 245  Permutation Choice 1- D0        64 * 28            */
tform1( 63, 55, 47, 39, 31, 23, 15,  7)tform2( 62, 54, 46, 38, 30, 22, 14,  6)
tform1( 61, 53, 45, 37, 29, 21, 13,  5)tform2( 28, 20, 12,  4,  1,  1,  1,  1)
0xFF,
/* 278  Permutation Choice 2            56 * 48            */
tform1( 14, 17, 11, 24,  1,  5,  3, 28)tform2( 15,  6, 21, 10, 23, 19, 12,  4)
tform1( 26,  8, 16,  7, 27, 20, 13,  2)tform2( 41, 52, 31, 37, 47, 55, 30, 40)
tform1( 51, 45, 33, 48, 44, 49, 39, 56)tform2( 34, 53, 46, 42, 50, 36, 29, 32)
0xFF
};
/**/
/* Selection Functions */
static byte s[] = {
/* S1 */
       14,  4, 13,  1,  2, 15, 11,  8,  3, 10,  6, 12,  5,  9,  0,  7,
        0, 15,  7,  4, 14,  2, 13,  1, 10,  6, 12, 11,  9,  5,  3,  8,
        4,  1, 14,  8, 13,  6,  2, 11, 15, 12,  9,  7,  3, 10,  5,  0,
       15, 12,  8,  2,  4,  9,  1,  7,  5, 11,  3, 14, 10,  0,  6, 13,
/* S2 */
       15,  1,  8, 14,  6, 11,  3,  4,  9,  7,  2, 13, 12,  0,  5, 10,
        3, 13,  4,  7, 15,  2,  8, 14, 12,  0,  1, 10,  6,  9, 11,  5,
        0, 14,  7, 11, 10,  4, 13,  1,  5,  8, 12,  6,  9,  3,  2, 15,
       13,  8, 10,  1,  3, 15,  4,  2, 11,  6,  7, 12,  0,  5, 14,  9,
/* S3 */
       10,  0,  9, 14,  6,  3, 15,  5,  1, 13, 12,  7, 11,  4,  2,  8,
       13,  7,  0,  9,  3,  4,  6, 10,  2,  8,  5, 14, 12, 11, 15,  1,
       13,  6,  4,  9,  8, 15,  3,  0, 11,  1,  2, 12,  5, 10, 14,  7,
        1, 10, 13,  0,  6,  9,  8,  7,  4, 15, 14,  3, 11,  5,  2, 12,
/* S4 */
        7, 13, 14,  3,  0,  6,  9, 10,  1,  2,  8,  5, 11, 12,  4, 15,
       13,  8, 11,  5,  6, 15,  0,  3,  4,  7,  2, 12,  1, 10, 14,  9,
       10,  6,  9,  0, 12, 11,  7, 13, 15,  1,  3, 14,  5,  2,  8,  4,
        3, 15,  0,  6, 10,  1, 13,  8,  9,  4,  5, 11, 12,  7,  2, 14,
/* S5 */
        2, 12,  4,  1,  7, 10, 11,  6,  8,  5,  3, 15, 13,  0, 14,  9,
       14, 11,  2, 12,  4,  7, 13,  1,  5,  0, 15, 10,  3,  9,  8,  6,
        4,  2,  1, 11, 10, 13,  7,  8, 15,  9, 12,  5,  6,  3,  0, 14,
       11,  8, 12,  7,  1, 14,  2, 13,  6, 15,  0,  9, 10,  4,  5,  3,
/* S6 */
       12,  1, 10, 15,  9,  2,  6,  8,  0, 13,  3,  4, 14,  7,  5, 11,
       10, 15,  4,  2,  7, 12,  9,  5,  6,  1, 13, 14,  0, 11,  3,  8,
        9, 14, 15,  5,  2,  8, 12,  3,  7,  0,  4, 10,  1, 13, 11,  6,
        4,  3,  2, 12,  9,  5, 15, 10, 11, 14,  1,  7,  6,  0,  8, 13,
/* S7 */
        4, 11,  2, 14, 15,  0,  8, 13,  3, 12,  9,  7,  5, 10,  6,  1,
       13,  0, 11,  7,  4,  9,  1, 10, 14,  3,  5, 12,  2, 15,  8,  6,
        1,  4, 11, 13, 12,  3,  7, 14, 10, 15,  6,  8,  0,  5,  9,  2,
        6, 11, 13,  8,  1,  4, 10,  7,  9,  5,  0, 15, 14,  2,  3, 12,
/* S8 */
       13,  2,  8,  4,  6, 15, 11,  1, 10,  9,  3, 14,  5,  0, 12,  7,
        1, 15, 13,  8, 10,  3,  7,  4, 12,  5,  6, 11,  0, 14,  9,  2,
        7, 11,  4,  1,  9, 12, 14,  2,  0,  6, 10, 13, 15,  3,  5,  8,
        2,  1, 14,  7,  4, 10,  8, 13, 15, 12,  9,  0,  3,  5,  6, 11
};

/**/
/*
   Shift Values
 */
static byte shft[] =  { 1, 1, 2, 2, 2, 2, 2, 2, 1, 2, 2, 2, 2, 2, 2, 1 };

void TRANSFORM( unsigned int* in, unsigned int* out, unsigned int base_rule )

/* transform up to 64 bits according to a rule */
{

    static unsigned int bits[] =  { 0x8000,
                                    0x4000,
                                    0x2000,
                                    0x1000,
                                    0x0800,
                                    0x0400,
                                    0x0200,
                                    0x0100,
                                    0x0080,
                                    0x0040,
                                    0x0020,
                                    0x0010,
                                    0x0008,
                                    0x0004,
                                    0x0002,
                                    0x0001 };

    unsigned int outword,x,i;

    i = 0;
    outword = 0;
    while ( (x = rules[base_rule]) != 0xFF ) {
        outword <<= 1;               /* shift the result left one bit   */
                                     /* (x & 060) >> 4 is index into in */
                                     /* x & 017        is bit #  in     */

        outword |= ( (in[ (x & 0x30 ) >> 4 ] & bits[ x & 0x0f ]) ? 1 : 0 );

        if (x & 0x80) {
            out[i] = outword;
            i++;
        };
        base_rule++;
    }
}

/**/
unsigned int bf( unsigned int x, unsigned int p1, unsigned int p2)
/* get bit field from bit p1 to bit p2 */
/* bits are numbered msb=0, lsb=15 */
{

    return ( (x >> 15-p2) & ~(~0 << p2-p1+1) );

}

#define s_function(s_value,in)  s[ s_value + map[in] ]

void SELECT( unsigned int* in, unsigned int* out )
{
    static byte map[] = {
        0, 16,  1, 17,  2, 18,  3, 19,  4, 20,  5, 21,  6, 22,  7, 23,
        8, 24,  9, 25, 10, 26, 11, 27, 12, 28, 13, 29, 14, 30, 15, 31,
       32, 48, 33, 49, 34, 50, 35, 51, 36, 52, 37, 53, 38, 54, 39, 55,
       40, 56, 41, 57, 42, 58, 43, 59, 44, 60, 45, 61, 46, 62, 47, 63
    };

    unsigned int hi, lo;

    hi     = s_function(   0, bf(in[0],0,5)  )                          << 4  |
             s_function(  64, bf(in[0],6,11) )                          ;
    lo     = s_function( 128, ((bf(in[0],12,15) << 2) | bf(in[1],0,1))) <<  4 |
             s_function( 192, bf(in[1],2,7)  );
    lo     = lo & 0xFF;
    out[0] = hi * 0x100 + lo;

    hi     = s_function( 256, bf(in[1],8,13) )                          << 4  |
             s_function( 320, ((bf(in[1],14,15) << 4) | bf(in[2],0,3))) ;
    lo     = s_function( 384, bf(in[2],4,9)  )                          <<  4 |
             s_function( 448, bf(in[2],10,15));
    lo     = lo & 0xFF;
    out[1] = hi * 0x100 + lo;

}

/**/
void SETKS( unsigned int* key, unsigned int* subkeys )
{
    unsigned int i,
                 y,
                 z,
                 C[2],       /* key permutation register 28 bits */
                 D[2],       /* key permutation register 28 bits */
                 CD[4];      /* combined key permutation register 56 bits */

    TRANSFORM( key, C, PC1A );
    TRANSFORM( key, D, PC1B );

    for ( i = 0 ; i <= 15 ; i++ )
    {
        y = shft[i];
        switch(y)
        {
        case 1 : z = bf(C[0],0,0);
		 C[0] = bf(C[0],1,15) << 01;              /* 1.0.2 */
                 C[0] |=  bf(C[1],0,0);
		 C[1] = bf(C[1],1,11) << 05;              /* 1.0.2 */
                 C[1] |=  z << 4;

                 z = bf(D[0],0,0);
		 D[0] = bf(D[0],1,15) << 01;              /* 1.0.2 */
                 D[0] |=  bf(D[1],0,0);
		 D[1] = bf(D[1],1,11) << 05;              /* 1.0.2 */
                 D[1] |=  z << 4;

                 break;

        case 2 : z = bf(C[0],0,1);
		 C[0] = bf(C[0],2,15) << 02;              /* 1.0.2 */
                 C[0] |=  bf(C[1],0,1);
		 C[1] = bf(C[1],2,11) << 06;              /* 1.0.2 */
                 C[1] |=  z << 4;

                 z = bf(D[0],0,1);
		 D[0] = bf(D[0],2,15) << 02;              /* 1.0.2 */
                 D[0] |=  bf(D[1],0,1);
		 D[1] = bf(D[1],2,11) << 06;              /* 1.0.2 */
                 D[1] |=  z << 4;

                 break;
        }
        CD[0] = C[0];
        CD[1] = bf(C[1],0,11) << 4 | bf(D[0],0,3);
        CD[2] = bf(D[0],4,15) << 4 | bf(D[1],0,3);
        CD[3] = bf(D[1],4,15) << 4;
        TRANSFORM( CD, &subkeys[3*i], PC2 );
    }

}

/**/
void DES( unsigned int* text, unsigned int* key, unsigned int encrypt, unsigned int* work)
{
    int start = 15, /* defaults are set to decode values */
        end_  = -1,
        incr  = -1;

    unsigned int L[4],       /* leftmost (and rightmost) 32 bits */
                 TEMP1[4],
                 TEMP2[4];
    int          i,xq;

    if ( encrypt )
    {
        start = 0;
        end_  = 16;
        incr  = 1;
    }

    TRANSFORM( text, L, IP );

    if ( work[0] != key[0] ||   /* if the key in the work area is the same as */
         work[1] != key[1] ||   /* the supplied key, the subkeys in the sork  */
         work[2] != key[2] ||   /* area have already been calculated          */
         work[3] != key[3] )
    {
         work[0] = key[0];
         work[1] = key[1];
         work[2] = key[2];
         work[3] = key[3];

         SETKS( key, &work[4] );
    }

    i = start;
    do
    {
        TRANSFORM( &L[2], TEMP1, E );
        xq = 3*i + 4;
        TEMP2[0] = TEMP1[0] ^ work[xq++];
        TEMP2[1] = TEMP1[1] ^ work[xq++];
        TEMP2[2] = TEMP1[2] ^ work[xq++];

        SELECT( TEMP2, TEMP1 );
        TRANSFORM( TEMP1, TEMP2, P );

        TEMP1[0] = TEMP2[0] ^ L[0];
        TEMP1[1] = TEMP2[1] ^ L[1];

        L[0] = L[2];         /* L ':=' R for 2 */
        L[1] = L[3];
        L[2] = TEMP1[0];     /* R ':=' TEMP1 for 2 */
        L[3] = TEMP1[1];

        i += incr;
    }
    while (i != end_);

    TEMP1[2] = L[0];        /* TEMP1[2] ':=' L for 2 */
    TEMP1[3] = L[1];

    TRANSFORM( TEMP1, text, IP_1 );
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜理伦三级在线观看| 激情五月婷婷综合| 一本大道综合伊人精品热热| 国产清纯在线一区二区www| 精品一区二区日韩| 精品粉嫩aⅴ一区二区三区四区| 久久精品久久精品| 国产亚洲女人久久久久毛片| 国产一区在线精品| 国产精品久久久久久久久免费丝袜| 成人黄色国产精品网站大全在线免费观看 | 色一区在线观看| 亚洲激情欧美激情| 制服.丝袜.亚洲.中文.综合| 青青草视频一区| 久久久久九九视频| 色婷婷综合久久久中文一区二区| 丝袜美腿成人在线| 久久久久一区二区三区四区| 国产成人免费xxxxxxxx| 亚洲免费高清视频在线| 欧美精品xxxxbbbb| 国产精品一二三四| 亚洲国产精品麻豆| 久久久久久久免费视频了| 91在线看国产| 日本网站在线观看一区二区三区 | 日韩欧美一区二区视频| 成人福利视频在线| 五月天婷婷综合| 国产精品女主播av| 欧美一区二区久久久| 成人精品gif动图一区| 午夜视频在线观看一区二区三区| 久久只精品国产| 在线欧美日韩国产| 国产美女久久久久| 亚洲123区在线观看| 亚洲国产精品av| 日韩三级高清在线| 欧美无乱码久久久免费午夜一区 | 国产成人综合亚洲网站| 一区二区三区日韩欧美精品| 欧美大黄免费观看| 在线一区二区视频| 国产a级毛片一区| 久草精品在线观看| 午夜精品福利久久久| 中文字幕亚洲在| 久久精品夜夜夜夜久久| 欧美日韩国产另类不卡| 91色视频在线| 成人毛片视频在线观看| 久久精品国产精品青草| 亚洲一级二级三级在线免费观看| 国产女同性恋一区二区| 日韩视频在线一区二区| 欧美性猛交xxxx乱大交退制版| 岛国精品一区二区| 国产乱码一区二区三区| 久久国产精品露脸对白| 天天操天天干天天综合网| 亚洲私人影院在线观看| 国产欧美日韩不卡免费| 26uuu亚洲综合色欧美 | 色婷婷久久久综合中文字幕| 国产成人精品影视| 精品一区二区三区蜜桃| 麻豆国产欧美日韩综合精品二区| 天天影视涩香欲综合网| 亚洲精品免费在线观看| 综合久久综合久久| 亚洲色图欧洲色图婷婷| 最好看的中文字幕久久| 亚洲视频小说图片| 亚洲精品乱码久久久久| 亚洲桃色在线一区| 一区二区三区在线影院| 亚洲乱码一区二区三区在线观看| 亚洲欧美在线另类| 亚洲欧洲三级电影| 亚洲欧洲日韩综合一区二区| 中文字幕一区二区三区在线播放 | 国产精品不卡在线观看| 国产精品高潮久久久久无| 亚洲视频在线观看三级| 亚洲综合av网| 日韩专区在线视频| 老司机午夜精品| 成人小视频免费观看| 不卡视频在线观看| 91国模大尺度私拍在线视频| 欧美日韩中文字幕一区二区| 91精品蜜臀在线一区尤物| 欧美不卡视频一区| 国产亚洲一区二区三区在线观看| 国产精品丝袜久久久久久app| 亚洲国产岛国毛片在线| 中日韩av电影| 国产精品国产三级国产有无不卡| 国产精品久久久久久久久动漫| 一区二区三区四区乱视频| 亚洲精品亚洲人成人网在线播放| 亚洲黄色免费电影| 亚洲国产精品视频| 日韩av中文字幕一区二区| 丝袜亚洲另类欧美| 午夜欧美在线一二页| 日韩成人精品在线观看| 天堂va蜜桃一区二区三区漫画版| 天天综合色天天综合色h| 免费观看在线综合| 国产传媒日韩欧美成人| 91福利在线看| 日韩欧美亚洲一区二区| 欧美成人福利视频| 中文字幕乱码日本亚洲一区二区| 国产精品久久久久久久裸模| 欧美精彩视频一区二区三区| 亚洲黄色小视频| 六月丁香综合在线视频| 成人国产精品免费观看视频| 色婷婷av一区二区三区软件| 欧美日韩一区久久| 91精品国产综合久久久久久久 | 欧美在线free| 日韩欧美一二区| 亚洲高清在线精品| 国产一区二区三区久久悠悠色av| 久久99热这里只有精品| 99久久国产综合精品麻豆| 67194成人在线观看| 欧美tickling挠脚心丨vk| 一区二区三区**美女毛片| 免费看日韩a级影片| 成人激情黄色小说| 日韩欧美一二区| 自拍偷拍欧美精品| 狠狠色丁香婷婷综合| 色综合久久久久综合体桃花网| 日韩亚洲欧美一区| 亚洲精品久久久蜜桃| 精品一区二区三区免费视频| 在线观看区一区二| 日韩精品最新网址| 视频一区欧美日韩| www.av精品| 精品少妇一区二区三区免费观看| 亚洲婷婷国产精品电影人久久| 久色婷婷小香蕉久久| 在线观看91精品国产麻豆| 中文字幕在线免费不卡| 久久99精品久久久| 欧美色爱综合网| 中文字幕制服丝袜一区二区三区 | 国产原创一区二区三区| 欧美日韩激情在线| 亚洲欧美另类久久久精品2019| 国产精品亚洲综合一区在线观看| 717成人午夜免费福利电影| 亚洲人精品午夜| 成人禁用看黄a在线| 欧美xxxx老人做受| 国产女主播一区| 成人丝袜高跟foot| 日韩免费一区二区| 丝袜亚洲另类丝袜在线| 日本二三区不卡| wwwwxxxxx欧美| 国产老女人精品毛片久久| 欧美一级欧美三级在线观看| 亚洲激情在线播放| 91一区二区在线| 综合色天天鬼久久鬼色| 色哟哟一区二区三区| 日韩理论片在线| 99精品国产一区二区三区不卡| 久久日韩粉嫩一区二区三区| 亚洲午夜成aⅴ人片| 91精品中文字幕一区二区三区| 亚洲另类在线视频| 91蜜桃网址入口| 亚洲日本在线看| 国产精品自在在线| 亚洲视频免费看| 91久久一区二区| 最新热久久免费视频| 99久久伊人网影院| 亚洲麻豆国产自偷在线| 91亚洲精品久久久蜜桃网站 | 一区二区在线观看视频| 欧洲精品视频在线观看| 亚洲最大色网站| 777午夜精品视频在线播放| 日韩成人午夜精品| 精品国产免费视频| 国产二区国产一区在线观看| 久久久久久黄色| 色综合中文字幕国产 | 国产精品午夜在线|