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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? rijndael.c

?? IBM的Linux上的PKCS#11實(shí)現(xiàn)
?? C
?? 第 1 頁 / 共 3 頁
字號(hào):
        CK_KEY_TYPE             key_type = CKK_AES;        CK_UTF8CHAR             label[] = "AES secret key object";        CK_BBOOL                true = TRUE;        CK_ATTRIBUTE            template[] = {                {CKA_CLASS,     &class,         sizeof(class)},                {CKA_KEY_TYPE,  &key_type,      sizeof(key_type)},                {CKA_TOKEN,     &true,          sizeof(true)},                {CKA_LABEL,     label,          sizeof(label)-1},                {CKA_ENCRYPT,   &true,          sizeof(true)},                {CKA_VALUE,     key256,         sizeof(key256)},                {CKA_VALUE_LEN, &key_size,      sizeof(key_size)}        };        CK_OBJECT_HANDLE        h_key;        CK_MECHANISM            mech;        memset( key256, 0, sizeof(key256) );        memset( pt, 0, sizeof(pt) );        memset( ct, 0, sizeof(ct) );        memset( final_pt, 0, sizeof(final_pt) );		if( (rc = funcs->C_CreateObject(sess, template, 7, &h_key)) != CKR_OK) {		OC_ERR_MSG("C_CreateObject #1", rc);		goto done;	}	        mech.mechanism = CKM_AES_ECB;        mech.ulParameterLen = 0;        mech.pParameter = NULL;        for( i=0; i<400; i++) {                if(i==399)                        memcpy(final_pt, ct+16, sizeof(final_pt));                for( j=0; j<10000; j++) {			memcpy(ct, ct+16, 16);                        rc = funcs->C_EncryptInit(sess, &mech, h_key);                        if (rc != CKR_OK) {                                OC_ERR_MSG("   C_EncryptInit #1", rc);                                goto done;                        }                        rc = funcs->C_Encrypt(sess, pt, pt_len, ct+16, &ct_len);                        if (rc != CKR_OK) {                                OC_ERR_MSG("   C_Encrypt #1", rc);                                goto done;                        }                        /* After the final encrypt, we need to keep the                         * plain text pure */                        if(i == 399 && j == 9999)                                goto print_done;                        else {                                memcpy(pt, ct+16, sizeof(pt));			}                }                for( k=0; k<sizeof(ct); k++)                        key256[k] ^= ct[k];                if( (rc = funcs->C_DestroyObject(sess, h_key)) != CKR_OK) {                        OC_ERR_MSG("C_DestroyObject", rc);                        goto done;                }                if( (rc = funcs->C_CreateObject(sess, template, 7, &h_key)) != CKR_OK) {                        OC_ERR_MSG("C_CreateObject #2", rc);                        goto done;                }                /* One status tick */                if(!(i%5)) {                        printf(".");                        fflush(stdout);                }        }print_done:	printf("\n");        for( i=0; i<sizeof(key256); i++) {                if(key256[i] != KAT_256_ECB_KEY[i]) {                        printf("%s:%d Error: key data does not match known "                                "key data at byte %d.\n", __FILE__, __LINE__, i);			rc = -1;                        goto done;                }        }        for( i=0; i<sizeof(final_pt); i++) {                if(final_pt[i] != KAT_256_ECB_PT[i]) {                        printf("%s:%d Error: Plain text does not match known "                                "plain text at byte %d.\n", __FILE__, __LINE__, i);			rc = -1;                        goto done;                }        }        for( i=0; i<AES_BLOCK_SIZE; i++) {                if(ct[i+16] != KAT_256_ECB_CT[i]) {                        printf("%s:%d Error: Cipher text does not match known "                                "cipher text at byte %d.\n", __FILE__, __LINE__, i);			rc = -1;                        goto done;                }        }done:        return rc;}int do_AES_KAT_128_CBC(void){        int                     i, j, k;        CK_RV                   rc;        CK_BYTE                 pt[AES_BLOCK_SIZE],                                ct[16],				old_ct[16],                                final_pt[AES_BLOCK_SIZE],                                key[AES_KEY_SIZE_128],				iv[AES_BLOCK_SIZE],				cv[AES_BLOCK_SIZE];        CK_ULONG                pt_len = AES_BLOCK_SIZE;        CK_ULONG                ct_len = AES_BLOCK_SIZE;        CK_ULONG                key_size = AES_KEY_SIZE_128;        CK_OBJECT_CLASS         class = CKO_SECRET_KEY;        CK_KEY_TYPE             key_type = CKK_AES;        CK_UTF8CHAR             label[] = "AES secret key object";        CK_BBOOL                true = TRUE;        CK_ATTRIBUTE            template[] = {                {CKA_CLASS,     &class,         sizeof(class)},                {CKA_KEY_TYPE,  &key_type,      sizeof(key_type)},                {CKA_TOKEN,     &true,          sizeof(true)},                {CKA_LABEL,     label,          sizeof(label)-1},                {CKA_ENCRYPT,   &true,          sizeof(true)},                {CKA_VALUE,     key,		sizeof(key)},                {CKA_VALUE_LEN, &key_size,      sizeof(key_size)}        };        CK_OBJECT_HANDLE        h_key;        CK_MECHANISM            mech;        memset( key, 0, sizeof(key) );        memset( pt, 0, sizeof(pt) );        memset( ct, 0, sizeof(ct) );	memset( old_ct, 0, sizeof(ct) );        memset( final_pt, 0, sizeof(final_pt) );	memset( iv, 0, sizeof(iv) );	memset( cv, 0, sizeof(cv) );        if( (rc = funcs->C_CreateObject(sess, template, 7, &h_key)) != CKR_OK) {                OC_ERR_MSG("C_CreateObject #1", rc);                goto done;        }        mech.mechanism = CKM_AES_CBC;        mech.ulParameterLen = sizeof(iv);        mech.pParameter = iv;	        for( i=0; i<400; i++) {                if(i==399)                        memcpy(final_pt, pt, sizeof(final_pt));		// Record i, key, cv, pt                for( j=0; j<10000; j++) {			for(k=0; k<sizeof(cv); k++) 				pt[k] ^= cv[k];						memcpy(old_ct, ct, sizeof(old_ct));			                        rc = funcs->C_EncryptInit(sess, &mech, h_key);                        if (rc != CKR_OK) {                                OC_ERR_MSG("   C_EncryptInit #1", rc);                                goto done;                        }                        rc = funcs->C_Encrypt(sess, pt, pt_len, ct, &ct_len);                        if (rc != CKR_OK) {                                OC_ERR_MSG("   C_Encrypt #1", rc);                                goto done;                        }			memcpy(pt, old_ct, sizeof(pt));			memcpy(cv, ct, sizeof(ct));						/* After the final encrypt, we need to keep the                         * plain text pure */                        if(i == 399 && j == 9999)                                goto print_done;                }		// Record ct                for( k=0; k<sizeof(ct); k++)                        key[k] ^= ct[k];                if( (rc = funcs->C_DestroyObject(sess, h_key)) != CKR_OK) {                        OC_ERR_MSG("C_DestroyObject", rc);                        goto done;                }                if( (rc = funcs->C_CreateObject(sess, template, 7, &h_key)) != CKR_OK) {                        OC_ERR_MSG("C_CreateObject #2", rc);                        goto done;                }                /* One status tick */                if(!(i%5)) {                        printf(".");                        fflush(stdout);                }        }print_done:        printf("\n");        for( i=0; i<sizeof(key); i++) {                if(key[i] != KAT_128_CBC_KEY[i]) {                        printf("%s:%d Error: key data does not match known "                                "key data at byte %d.\n", __FILE__, __LINE__, i);                        rc = -1;                        goto done;                }        }        for( i=0; i<sizeof(final_pt); i++) {                if(final_pt[i] != KAT_128_CBC_PT[i]) {                        printf("%s:%d Error: Plain text does not match known "                                "plain text at byte %d.\n", __FILE__, __LINE__, i);                        rc = -1;                        goto done;                }        }        for( i=0; i<AES_BLOCK_SIZE; i++) {                if(ct[i] != KAT_128_CBC_CT[i]) {                        printf("%s:%d Error: Cipher text does not match known "                                "cipher text at byte %d.\n", __FILE__, __LINE__, i);                        rc = -1;                        goto done;                }        }done:        return rc;}int do_AES_KAT_192_CBC(void){        int                     i, j, k;        CK_RV                   rc;        CK_BYTE                 pt[AES_BLOCK_SIZE],				old_ct[AES_BLOCK_SIZE],                                ct[24], // larger to acct for trailing ciphertext                                final_pt[AES_BLOCK_SIZE],				cv[AES_BLOCK_SIZE],				iv[AES_BLOCK_SIZE];        CK_BYTE                 key[AES_KEY_SIZE_192];        CK_ULONG                pt_len = AES_BLOCK_SIZE;        CK_ULONG                ct_len = AES_BLOCK_SIZE;        CK_ULONG                key_size = AES_KEY_SIZE_192;        CK_OBJECT_CLASS         class = CKO_SECRET_KEY;        CK_KEY_TYPE             key_type = CKK_AES;        CK_UTF8CHAR             label[] = "AES secret key object";        CK_BBOOL                true = TRUE;        CK_ATTRIBUTE            template[] = {                {CKA_CLASS,     &class,         sizeof(class)},                {CKA_KEY_TYPE,  &key_type,      sizeof(key_type)},                {CKA_TOKEN,     &true,          sizeof(true)},                {CKA_LABEL,     label,          sizeof(label)-1},                {CKA_ENCRYPT,   &true,          sizeof(true)},                {CKA_VALUE,     key,            sizeof(key)},                {CKA_VALUE_LEN, &key_size,      sizeof(key_size)}        };        CK_OBJECT_HANDLE        h_key;        CK_MECHANISM            mech;        memset( key, 0, sizeof(key) );        memset( pt, 0, sizeof(pt) );        memset( ct, 0, sizeof(ct) );        memset( cv, 0, sizeof(cv) );        memset( final_pt, 0, sizeof(final_pt) );	memset( iv, 0, sizeof(iv) );        if( (rc = funcs->C_CreateObject(sess, template, 7, &h_key)) != CKR_OK) {                OC_ERR_MSG("C_CreateObject #1", rc);                goto done;        }        mech.mechanism = CKM_AES_CBC;        mech.ulParameterLen = sizeof(iv);        mech.pParameter = iv;        for( i=0; i<400; i++) {                if(i==399)                        memcpy(final_pt, pt, sizeof(final_pt));                for( j=0; j<10000; j++) {			for( k=0; k<sizeof(pt); k++)				pt[k] ^= cv[k];			                        memcpy(old_ct, ct+8, sizeof(old_ct));                        rc = funcs->C_EncryptInit(sess, &mech, h_key);                        if (rc != CKR_OK) {                                OC_ERR_MSG("   C_EncryptInit #1", rc);                                goto done;                        }                        rc = funcs->C_Encrypt(sess, pt, pt_len, ct+8, &ct_len);                        if (rc != CKR_OK) {                                OC_ERR_MSG("   C_Encrypt #1", rc);                                goto done;                        }			memcpy(ct, old_ct+8, 8);			memcpy(pt, old_ct, sizeof(pt));			memcpy(cv, ct+8, sizeof(cv));                        if(i == 399 && j == 9999)                                goto print_done;                }                for( k=0; k<sizeof(ct); k++)                        key[k] ^= ct[k];                if( (rc = funcs->C_DestroyObject(sess, h_key)) != CKR_OK) {                        OC_ERR_MSG("C_DestroyObject", rc);                        goto done;                }                if( (rc = funcs->C_CreateObject(sess, template, 7, &h_key)) != CKR_OK) {                        OC_ERR_MSG("C_CreateObject #2", rc);                        goto done;                }                /* One status tick */                if(!(i%5)) {                        printf(".");                        fflush(stdout);                }        }print_done:        printf("\n");        for( i=0; i<sizeof(key); i++) {                if(key[i] != KAT_192_CBC_KEY[i]) {                        printf("%s:%d Error: key data does not match known "                                "key data at byte %d.\n", __FILE__, __LINE__, i);                        rc = -1;                        goto done;                }        }        for( i=0; i<sizeof(final_pt); i++) {                if(final_pt[i] != KAT_192_CBC_PT[i]) {                        printf("%s:%d Error: Plain text does not match known "                                "plain text at byte %d.\n", __FILE__, __LINE__, i);                        rc = -1;                        goto done;                }        }        for( i=0; i<AES_BLOCK_SIZE; i++) {                if(ct[i+8] != KAT_192_CBC_CT[i]) {                        printf("%s:%d Error: Cipher text does not match known "                                "cipher text at byte %d.\n", __FILE__, __LINE__, i);                        rc = -1;                        goto done;                }        }done:

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成人av电影在线播放| 五月激情综合婷婷| 亚洲国产精品一区二区久久| 亚洲免费av网站| 亚洲国产精品久久久男人的天堂| 91福利国产精品| 欧美精品在线一区二区| 久久久久久一级片| 中文字幕一区二区三区乱码在线 | 韩国毛片一区二区三区| 国产精品亚洲专一区二区三区| 中文字幕成人在线观看| 亚洲精品菠萝久久久久久久| 美女脱光内衣内裤视频久久网站 | 日本在线播放一区二区三区| 国产精品一区二区三区99| 久久综合国产精品| 亚洲va韩国va欧美va| 一本色道久久综合亚洲aⅴ蜜桃| 久久久久久一二三区| 欧美综合亚洲图片综合区| 中文字幕一区二区三区四区不卡| 在线观看日韩av先锋影音电影院| 日韩综合小视频| 欧美一区二区美女| 天涯成人国产亚洲精品一区av| 久久伊人中文字幕| 精品国产污污免费网站入口 | 91麻豆精品国产自产在线| 日韩理论片在线| 99久久国产综合精品色伊| 亚洲精品在线免费观看视频| 91在线视频官网| 激情图片小说一区| 日本vs亚洲vs韩国一区三区二区| 日韩欧美中文字幕制服| 五月激情综合色| 亚洲影视在线观看| 欧美三级午夜理伦三级中视频| 一区二区三区日韩精品视频| 欧美三级一区二区| 欧美在线一区二区| 成人在线一区二区三区| 久久久欧美精品sm网站| 日韩午夜在线观看| 国产精品二三区| 亚洲精品老司机| 亚洲色图制服丝袜| 亚洲精品免费在线观看| ...xxx性欧美| 中文字幕在线一区| 国产精品久线观看视频| 亚洲精品午夜久久久| 亚洲精品国产无天堂网2021| 国产精品久久精品日日| 亚洲国产精品av| 国产精品沙发午睡系列990531| 成人高清视频在线| 亚洲激情av在线| 免费日本视频一区| 成人avav影音| 欧美一区二区三区免费观看视频 | 麻豆视频观看网址久久| 久久电影国产免费久久电影 | 亚洲国产精品欧美一二99| 日韩一级大片在线观看| 精品国产伦一区二区三区观看方式| 亚洲国产精品黑人久久久| 亚洲精品综合在线| 激情六月婷婷久久| 日本黄色一区二区| 精品国产一区a| 亚洲午夜免费福利视频| 大尺度一区二区| 日韩午夜激情av| 亚洲男人的天堂一区二区| 日韩黄色在线观看| 91福利在线观看| 综合久久给合久久狠狠狠97色| 久久不见久久见中文字幕免费| 99re在线精品| 国产精品成人免费精品自在线观看 | 亚洲美女视频在线| 国产69精品一区二区亚洲孕妇| 欧美欧美欧美欧美| 91污片在线观看| 懂色中文一区二区在线播放| 成人免费三级在线| 国产欧美中文在线| 欧美经典三级视频一区二区三区| 亚洲成人激情综合网| 欧美色精品在线视频| 国产精品久久久久久福利一牛影视| 久久97超碰色| 91美女福利视频| 国产精品高潮呻吟| caoporen国产精品视频| 欧美一区二区三区思思人| 婷婷久久综合九色综合绿巨人| 欧洲一区二区av| 亚洲va欧美va国产va天堂影院| 欧美日韩精品专区| 久久激情五月激情| 国产日韩影视精品| 日本伦理一区二区| 日韩精品1区2区3区| 久久久亚洲精华液精华液精华液 | 日韩影院免费视频| 亚洲精品一线二线三线 | 国产精品久久久久婷婷| 成人手机电影网| 亚洲午夜精品在线| 2023国产精华国产精品| 色综合色狠狠天天综合色| 日韩中文字幕91| 国产精品私人自拍| 欧美高清www午色夜在线视频| 国产一区二区0| 日韩一区二区三区视频在线| 高清久久久久久| 人禽交欧美网站| 亚洲精品免费一二三区| 精品久久久久久亚洲综合网| 青青草国产精品97视觉盛宴 | 久久久不卡网国产精品二区| 色婷婷狠狠综合| 成人av电影在线| 成人午夜短视频| 日本不卡免费在线视频| 亚洲国产综合视频在线观看| 中文在线免费一区三区高中清不卡| 欧美视频一二三区| 天天色天天操综合| 日韩综合小视频| 91精品国产综合久久久久久| 9i在线看片成人免费| 国产乱码精品1区2区3区| 日韩成人av影视| 日韩中文字幕不卡| 蜜臀av性久久久久蜜臀aⅴ流畅| 亚洲成人手机在线| 午夜精品久久久久久久久久久| 一区二区免费在线| 一区二区在线看| 一区二区久久久久久| 一区二区三区在线不卡| 亚洲国产美国国产综合一区二区| 亚洲欧洲成人精品av97| 亚洲精品一区二区三区蜜桃下载 | 欧美一区二区在线观看| 欧美tk丨vk视频| 中文字幕高清一区| 国产精品久线在线观看| 亚洲综合在线观看视频| 亚洲乱码国产乱码精品精可以看| 国产精品不卡在线| 亚洲影视资源网| 久久精品国产99国产| 亚洲激情一二三区| 麻豆精品视频在线观看免费 | 久久精品国产久精国产| 成人免费视频app| 在线不卡免费av| 中文字幕精品一区二区三区精品| 一区二区三区高清| 国产一区二区三区免费播放| 99久久精品国产导航| 4438x成人网最大色成网站| 日本一区二区视频在线| 丝袜诱惑制服诱惑色一区在线观看| 国产精品77777竹菊影视小说| 欧美日韩在线观看一区二区 | av亚洲精华国产精华精华| 欧美日韩你懂得| **欧美大码日韩| 国产一区二区网址| 欧美一区二区福利在线| 亚洲嫩草精品久久| 成人一区二区视频| 精品久久久久久亚洲综合网 | 亚洲成人高清在线| 欧美午夜在线观看| 亚洲欧美日韩久久| 国产成人免费视频网站高清观看视频| 久久久高清一区二区三区| 日韩有码一区二区三区| 欧美日韩精品一区二区三区| 亚洲欧洲色图综合| av成人免费在线| 国产精品免费视频网站| 国产成人午夜精品影院观看视频| 日韩欧美www| 亚洲欧美偷拍卡通变态| 91年精品国产| 亚洲精品亚洲人成人网| 欧美体内she精高潮| 婷婷中文字幕一区三区| 2024国产精品| 成人手机电影网| 午夜精品久久久久影视|