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

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

?? sshaes.c

?? 遠程登陸工具軟件源碼 用于遠程登陸unix
?? C
?? 第 1 頁 / 共 4 頁
字號:
    LASTWORD(0);
    LASTWORD(1);
    LASTWORD(2);
    LASTWORD(3);
    LASTWORD(4);
    LASTWORD(5);
    LASTWORD(6);
    LASTWORD(7);
    MOVEWORD(0);
    MOVEWORD(1);
    MOVEWORD(2);
    MOVEWORD(3);
    MOVEWORD(4);
    MOVEWORD(5);
    MOVEWORD(6);
    MOVEWORD(7);
    ADD_ROUND_KEY_8;
}

#undef MAKEWORD
#undef LASTWORD


/*
 * Set up an AESContext. `keylen' and `blocklen' are measured in
 * bytes; each can be either 16 (128-bit), 24 (192-bit), or 32
 * (256-bit).
 */
static void aes_setup(AESContext * ctx, int blocklen,
	       unsigned char *key, int keylen)
{
    int i, j, Nk, rconst;

    assert(blocklen == 16 || blocklen == 24 || blocklen == 32);
    assert(keylen == 16 || keylen == 24 || keylen == 32);

    /*
     * Basic parameters. Words per block, words in key, rounds.
     */
    Nk = keylen / 4;
    ctx->Nb = blocklen / 4;
    ctx->Nr = 6 + (ctx->Nb > Nk ? ctx->Nb : Nk);

    /*
     * Assign core-function pointers.
     */
    if (ctx->Nb == 8)
	ctx->encrypt = aes_encrypt_nb_8, ctx->decrypt = aes_decrypt_nb_8;
    else if (ctx->Nb == 6)
	ctx->encrypt = aes_encrypt_nb_6, ctx->decrypt = aes_decrypt_nb_6;
    else if (ctx->Nb == 4)
	ctx->encrypt = aes_encrypt_nb_4, ctx->decrypt = aes_decrypt_nb_4;

    /*
     * Now do the key setup itself.
     */
    rconst = 1;
    for (i = 0; i < (ctx->Nr + 1) * ctx->Nb; i++) {
	if (i < Nk)
	    ctx->keysched[i] = GET_32BIT_MSB_FIRST(key + 4 * i);
	else {
	    word32 temp = ctx->keysched[i - 1];
	    if (i % Nk == 0) {
		int a, b, c, d;
		a = (temp >> 16) & 0xFF;
		b = (temp >> 8) & 0xFF;
		c = (temp >> 0) & 0xFF;
		d = (temp >> 24) & 0xFF;
		temp = Sbox[a] ^ rconst;
		temp = (temp << 8) | Sbox[b];
		temp = (temp << 8) | Sbox[c];
		temp = (temp << 8) | Sbox[d];
		rconst = mulby2(rconst);
	    } else if (i % Nk == 4 && Nk > 6) {
		int a, b, c, d;
		a = (temp >> 24) & 0xFF;
		b = (temp >> 16) & 0xFF;
		c = (temp >> 8) & 0xFF;
		d = (temp >> 0) & 0xFF;
		temp = Sbox[a];
		temp = (temp << 8) | Sbox[b];
		temp = (temp << 8) | Sbox[c];
		temp = (temp << 8) | Sbox[d];
	    }
	    ctx->keysched[i] = ctx->keysched[i - Nk] ^ temp;
	}
    }

    /*
     * Now prepare the modified keys for the inverse cipher.
     */
    for (i = 0; i <= ctx->Nr; i++) {
	for (j = 0; j < ctx->Nb; j++) {
	    word32 temp;
	    temp = ctx->keysched[(ctx->Nr - i) * ctx->Nb + j];
	    if (i != 0 && i != ctx->Nr) {
		/*
		 * Perform the InvMixColumn operation on i. The D
		 * tables give the result of InvMixColumn applied
		 * to Sboxinv on individual bytes, so we should
		 * compose Sbox with the D tables for this.
		 */
		int a, b, c, d;
		a = (temp >> 24) & 0xFF;
		b = (temp >> 16) & 0xFF;
		c = (temp >> 8) & 0xFF;
		d = (temp >> 0) & 0xFF;
		temp = D0[Sbox[a]];
		temp ^= D1[Sbox[b]];
		temp ^= D2[Sbox[c]];
		temp ^= D3[Sbox[d]];
	    }
	    ctx->invkeysched[i * ctx->Nb + j] = temp;
	}
    }
}

static void aes_encrypt(AESContext * ctx, word32 * block)
{
    ctx->encrypt(ctx, block);
}

static void aes_decrypt(AESContext * ctx, word32 * block)
{
    ctx->decrypt(ctx, block);
}

static void aes_encrypt_cbc(unsigned char *blk, int len, AESContext * ctx)
{
    word32 iv[4];
    int i;

    assert((len & 15) == 0);

    memcpy(iv, ctx->iv, sizeof(iv));

    while (len > 0) {
	for (i = 0; i < 4; i++)
	    iv[i] ^= GET_32BIT_MSB_FIRST(blk + 4 * i);
	aes_encrypt(ctx, iv);
	for (i = 0; i < 4; i++)
	    PUT_32BIT_MSB_FIRST(blk + 4 * i, iv[i]);
	blk += 16;
	len -= 16;
    }

    memcpy(ctx->iv, iv, sizeof(iv));
}

static void aes_decrypt_cbc(unsigned char *blk, int len, AESContext * ctx)
{
    word32 iv[4], x[4], ct[4];
    int i;

    assert((len & 15) == 0);

    memcpy(iv, ctx->iv, sizeof(iv));

    while (len > 0) {
	for (i = 0; i < 4; i++)
	    x[i] = ct[i] = GET_32BIT_MSB_FIRST(blk + 4 * i);
	aes_decrypt(ctx, x);
	for (i = 0; i < 4; i++) {
	    PUT_32BIT_MSB_FIRST(blk + 4 * i, iv[i] ^ x[i]);
	    iv[i] = ct[i];
	}
	blk += 16;
	len -= 16;
    }

    memcpy(ctx->iv, iv, sizeof(iv));
}

static void *aes_make_context(void)
{
    return snew(AESContext);
}

static void aes_free_context(void *handle)
{
    sfree(handle);
}

static void aes128_key(void *handle, unsigned char *key)
{
    AESContext *ctx = (AESContext *)handle;
    aes_setup(ctx, 16, key, 16);
}

static void aes192_key(void *handle, unsigned char *key)
{
    AESContext *ctx = (AESContext *)handle;
    aes_setup(ctx, 16, key, 24);
}

static void aes256_key(void *handle, unsigned char *key)
{
    AESContext *ctx = (AESContext *)handle;
    aes_setup(ctx, 16, key, 32);
}

static void aes_iv(void *handle, unsigned char *iv)
{
    AESContext *ctx = (AESContext *)handle;
    int i;
    for (i = 0; i < 4; i++)
	ctx->iv[i] = GET_32BIT_MSB_FIRST(iv + 4 * i);
}

static void aes_ssh2_encrypt_blk(void *handle, unsigned char *blk, int len)
{
    AESContext *ctx = (AESContext *)handle;
    aes_encrypt_cbc(blk, len, ctx);
}

static void aes_ssh2_decrypt_blk(void *handle, unsigned char *blk, int len)
{
    AESContext *ctx = (AESContext *)handle;
    aes_decrypt_cbc(blk, len, ctx);
}

void aes256_encrypt_pubkey(unsigned char *key, unsigned char *blk, int len)
{
    AESContext ctx;
    aes_setup(&ctx, 16, key, 32);
    memset(ctx.iv, 0, sizeof(ctx.iv));
    aes_encrypt_cbc(blk, len, &ctx);
    memset(&ctx, 0, sizeof(ctx));
}

void aes256_decrypt_pubkey(unsigned char *key, unsigned char *blk, int len)
{
    AESContext ctx;
    aes_setup(&ctx, 16, key, 32);
    memset(ctx.iv, 0, sizeof(ctx.iv));
    aes_decrypt_cbc(blk, len, &ctx);
    memset(&ctx, 0, sizeof(ctx));
}

static const struct ssh2_cipher ssh_aes128 = {
    aes_make_context, aes_free_context, aes_iv, aes128_key,
    aes_ssh2_encrypt_blk, aes_ssh2_decrypt_blk,
    "aes128-cbc",
    16, 128, "AES-128"
};

static const struct ssh2_cipher ssh_aes192 = {
    aes_make_context, aes_free_context, aes_iv, aes192_key,
    aes_ssh2_encrypt_blk, aes_ssh2_decrypt_blk,
    "aes192-cbc",
    16, 192, "AES-192"
};

static const struct ssh2_cipher ssh_aes256 = {
    aes_make_context, aes_free_context, aes_iv, aes256_key,
    aes_ssh2_encrypt_blk, aes_ssh2_decrypt_blk,
    "aes256-cbc",
    16, 256, "AES-256"
};

static const struct ssh2_cipher ssh_rijndael128 = {
    aes_make_context, aes_free_context, aes_iv, aes128_key,
    aes_ssh2_encrypt_blk, aes_ssh2_decrypt_blk,
    "rijndael128-cbc",
    16, 128, "AES-128"
};

static const struct ssh2_cipher ssh_rijndael192 = {
    aes_make_context, aes_free_context, aes_iv, aes192_key,
    aes_ssh2_encrypt_blk, aes_ssh2_decrypt_blk,
    "rijndael192-cbc",
    16, 192, "AES-192"
};

static const struct ssh2_cipher ssh_rijndael256 = {
    aes_make_context, aes_free_context, aes_iv, aes256_key,
    aes_ssh2_encrypt_blk, aes_ssh2_decrypt_blk,
    "rijndael256-cbc",
    16, 256, "AES-256"
};

static const struct ssh2_cipher ssh_rijndael_lysator = {
    aes_make_context, aes_free_context, aes_iv, aes256_key,
    aes_ssh2_encrypt_blk, aes_ssh2_decrypt_blk,
    "rijndael-cbc@lysator.liu.se",
    16, 256, "AES-256"
};

static const struct ssh2_cipher *const aes_list[] = {
    &ssh_aes256,
    &ssh_rijndael256,
    &ssh_rijndael_lysator,
    &ssh_aes192,
    &ssh_rijndael192,
    &ssh_aes128,
    &ssh_rijndael128,
};

const struct ssh2_ciphers ssh2_aes = {
    sizeof(aes_list) / sizeof(*aes_list),
    aes_list
};

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕精品综合| 欧美日韩国产另类不卡| 久久亚洲一级片| 国模无码大尺度一区二区三区| 欧美大片国产精品| 国产一区二区三区av电影| 久久综合色天天久久综合图片| 国产一区二区三区最好精华液| 久久精品夜夜夜夜久久| 波多野结衣在线一区| 中文字幕亚洲精品在线观看| 99re成人在线| 日本系列欧美系列| 精品国产123| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 91捆绑美女网站| 亚洲自拍偷拍综合| 91精品欧美福利在线观看| 精品综合久久久久久8888| 欧美激情一区在线| 欧美日韩五月天| 国产一区不卡视频| 一个色综合av| 欧美成人精品福利| 色哟哟一区二区三区| 美脚の诱脚舐め脚责91| 亚洲欧洲国产日本综合| 91精品国产欧美日韩| 成人精品高清在线| 琪琪一区二区三区| 亚洲国产视频在线| 欧美激情综合五月色丁香小说| 97精品电影院| 国产在线视视频有精品| 一区二区高清视频在线观看| 亚洲精品在线观看网站| 91福利社在线观看| 国产a级毛片一区| 首页国产欧美久久| 亚洲欧洲制服丝袜| 久久综合九色综合97_久久久| 99re视频这里只有精品| 国模无码大尺度一区二区三区| 亚洲激情图片一区| 中文字幕的久久| 欧美成人免费网站| 欧美日韩精品一区二区| 91影院在线免费观看| 韩国女主播成人在线观看| 亚洲va国产天堂va久久en| 亚洲国产成人午夜在线一区| 91精品久久久久久蜜臀| 在线观看成人小视频| 成人午夜免费av| 国产乱对白刺激视频不卡| 午夜电影一区二区| 亚洲午夜精品网| 亚洲私人黄色宅男| 国产精品全国免费观看高清| 精品国产一区二区三区久久久蜜月| 欧美日韩一区三区四区| 在线免费观看日韩欧美| 色狠狠色狠狠综合| 99精品国产99久久久久久白柏| 国产成人鲁色资源国产91色综 | 777午夜精品视频在线播放| 91猫先生在线| 91视频国产资源| 成人av手机在线观看| 国产+成+人+亚洲欧洲自线| 国产精品一区二区久久不卡| 久久精品99国产精品日本| 日日摸夜夜添夜夜添精品视频| 亚洲一区二区欧美日韩| 一二三四社区欧美黄| 亚洲尤物视频在线| 成人激情av网| 成人免费视频免费观看| 成人免费视频国产在线观看| 风间由美一区二区av101| 成人永久免费视频| 99久久免费视频.com| 91啪亚洲精品| 色婷婷综合久久| 欧美日韩精品一二三区| 欧美一区二区视频网站| 欧美成人精品福利| 国产亚洲欧美日韩日本| 中文字幕在线不卡国产视频| 最新欧美精品一区二区三区| 一区二区欧美视频| 日本中文字幕一区| 激情综合网av| 成人av影院在线| 欧洲精品在线观看| 欧美精品久久99久久在免费线 | 欧美一区二区视频在线观看2020| 欧美美女网站色| 精品国产乱码久久久久久老虎| 久久综合九色综合欧美就去吻| 久久一留热品黄| 亚洲欧洲日韩女同| 亚洲777理论| 国产剧情一区在线| 色哟哟在线观看一区二区三区| 欧美日韩一级二级| 久久综合资源网| 1区2区3区精品视频| 亚洲国产成人av| 国产乱码字幕精品高清av| 99re6这里只有精品视频在线观看| 欧美午夜精品久久久久久超碰| 欧美一级二级三级乱码| 中文字幕国产一区| 亚洲国产一区二区a毛片| 国产美女娇喘av呻吟久久| 色综合久久中文字幕| 艳妇臀荡乳欲伦亚洲一区| 青青草原综合久久大伊人精品| 国产成人亚洲精品狼色在线| 欧美亚洲综合在线| 久久久噜噜噜久噜久久综合| 亚洲六月丁香色婷婷综合久久| 久久99久国产精品黄毛片色诱| 99国产精品国产精品久久| 日韩视频一区在线观看| 亚洲欧美色一区| 激情综合网av| 精品视频一区二区不卡| 国产精品私房写真福利视频| 五月天欧美精品| 成人精品视频.| 欧美本精品男人aⅴ天堂| 一区二区日韩av| 成a人片国产精品| 精品粉嫩aⅴ一区二区三区四区| 一区二区三区免费在线观看| 国产精品99久| 91精品国产入口在线| 亚洲精品你懂的| 波多野结衣在线一区| 2023国产一二三区日本精品2022| 亚洲国产视频一区| 91在线免费播放| 日本一区二区三区免费乱视频| 日本不卡一区二区| 欧美亚洲一区二区在线| 亚洲欧美日韩在线不卡| 成人av网站在线| 亚洲国产精品ⅴa在线观看| 另类小说欧美激情| 91精品黄色片免费大全| 亚洲午夜日本在线观看| 91丨porny丨中文| 国产精品天天摸av网| 国产福利一区二区三区| 精品国产1区2区3区| 裸体一区二区三区| 日韩一区二区三区av| 日韩精品视频网站| 91麻豆精品国产91| 日韩精品高清不卡| 欧美一区二区视频网站| 日韩成人免费看| 欧美一级搡bbbb搡bbbb| 日本麻豆一区二区三区视频| 337p亚洲精品色噜噜| 欧美aa在线视频| 日韩视频中午一区| 激情文学综合插| 久久久99精品久久| 国产不卡视频一区| 国产精品久久久久久久午夜片| 成人免费视频国产在线观看| 国产精品不卡一区二区三区| 99久久免费精品高清特色大片| 亚洲女子a中天字幕| 91久久一区二区| 亚洲第一电影网| 在线不卡中文字幕| 精品一区二区三区免费观看| 26uuu国产在线精品一区二区| 国产自产高清不卡| 国产精品麻豆一区二区 | 一本大道久久a久久综合婷婷 | 亚洲一区二区三区四区的| 欧美日韩国产一区二区三区地区| 午夜精品福利一区二区蜜股av | 亚洲欧美日韩在线不卡| 欧美伊人精品成人久久综合97 | 国产专区综合网| 国产精品伦理一区二区| 日本久久精品电影| 蜜臀国产一区二区三区在线播放| 久久综合久久久久88| 99视频有精品| 日韩经典一区二区| 久久精品一二三| 欧美视频第二页| 国产一区二区日韩精品|