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

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

?? bsdi_fmt.c

?? 著名的解Unix密碼的源程序
?? C
字號:
/* * This file is part of John the Ripper password cracker, * Copyright (c) 1996-98 by Solar Designer */#include <string.h>#include "arch.h"#include "misc.h"#include "DES_std.h"#include "common.h"#include "formats.h"#define FORMAT_LABEL			"bsdi"#define FORMAT_NAME			"BSDI DES"#define BENCHMARK_COMMENT		" (x725)"#define PLAINTEXT_LENGTH		64#define CIPHERTEXT_LENGTH		20static struct fmt_tests tests[] = {	{"_J9..CCCCXBrJUJV154M", "U*U*U*U*"},	{"_J9..CCCCXUhOBTXzaiE", "U*U***U"},	{"_J9..CCCC4gQ.mB/PffM", "U*U***U*"},	{"_J9..XXXXvlzQGqpPPdk", "*U*U*U*U"},	{"_J9..XXXXsqM/YSSP..Y", "*U*U*U*U*"},	{"_J9..XXXXVL7qJCnku0I", "*U*U*U*U*U*U*U*U"},	{"_J9..XXXXAj8cFbP5scI", "*U*U*U*U*U*U*U*U*"},	{"_J9..SDizh.vll5VED9g", "ab1234567"},	{"_J9..SDizRjWQ/zePPHc", "cr1234567"},	{"_J9..SDSD5YGyRCr4W4c", ""},	{NULL}};#if DES_BS#include "memory.h"#include "DES_bs.h"#define ALGORITHM_NAME			DES_BS_ALGORITHM_NAME#define BINARY_BITS			16#define BINARY_SIZE			(BINARY_BITS * ARCH_SIZE)#define SALT_SIZE			(ARCH_SIZE * 2)#define MIN_KEYS_PER_CRYPT		ARCH_BITS#define MAX_KEYS_PER_CRYPT		ARCH_BITS#else#define ALGORITHM_NAME			DES_STD_ALGORITHM_NAME#define BINARY_SIZE			ARCH_SIZE#define SALT_SIZE			(ARCH_SIZE * 2)#define MIN_KEYS_PER_CRYPT		4#define MAX_KEYS_PER_CRYPT		8ARCH_WORD saved_salt, current_salt;#endifint saved_count;static struct {#if DES_BS	char final[8];#else	union {		double dummy;		struct {			DES_KS KS;			DES_binary binary;		} data;	} aligned;#endif	char key[PLAINTEXT_LENGTH];} buffer[MAX_KEYS_PER_CRYPT];#if DES_BSstruct fmt_main fmt_BSDI;static int binary_bits = BINARY_BITS;static int keys_changed;#endifstatic void init(){	DES_std_init();#if DES_BS	if (mem_saving_level > 1) {		DES_bs_mem_saving = 1;		binary_bits = 32;		fmt_BSDI.params.binary_size = ARCH_SIZE;	}	DES_bs_init();	DES_std_set_salt(0);	DES_count = 1;#else	current_salt = -1;#endif}static int valid(char *ciphertext){	char *pos;	if (ciphertext[0] != '_') return 0;	for (pos = &ciphertext[1]; pos < &ciphertext[9]; pos++)	if (!*pos) return 0;	for (pos = &ciphertext[9]; atoi64[(ARCH_INDEX)*pos] >= 0; pos++);	return !*pos && pos - ciphertext == CIPHERTEXT_LENGTH;}static void *salt(char *ciphertext){	static ARCH_WORD out[2];#if DES_BS	out[0] = DES_raw_get_salt(ciphertext);#else	out[0] = DES_std_get_salt(ciphertext);#endif	out[1] = DES_raw_get_count(ciphertext);	return out;}#if DES_BSstatic int binary_hash_0(void *binary){	return DES_bs_binary_hash((ARCH_WORD *)binary, 4);}static int binary_hash_1(void *binary){	return DES_bs_binary_hash((ARCH_WORD *)binary, 8);}static int binary_hash_2(void *binary){	return DES_bs_binary_hash((ARCH_WORD *)binary, 12);}static int get_hash_0(int index){	return DES_bs_get_hash(index, 4);}static int get_hash_1(int index){	return DES_bs_get_hash(index, 8);}static int get_hash_2(int index){	return DES_bs_get_hash(index, 12);}static int salt_hash(void *salt){	return *(ARCH_WORD *)salt & 0x3FF;}static void set_salt(void *salt){	DES_bs_set_salt(*(ARCH_WORD *)salt);	saved_count = ((ARCH_WORD *)salt)[1];}#elsestatic int binary_hash_0(void *binary){	return DES_STD_HASH_0(*(ARCH_WORD *)binary);}static int binary_hash_1(void *binary){	return DES_STD_HASH_1(*(ARCH_WORD *)binary);}static int binary_hash_2(void *binary){	return DES_STD_HASH_2(*(ARCH_WORD *)binary);}static int get_hash_0(int index){	return DES_STD_HASH_0(buffer[index].aligned.data.binary[0]);}static int get_hash_1(int index){	ARCH_WORD binary;	binary = buffer[index].aligned.data.binary[0];	return DES_STD_HASH_1(binary);}static int get_hash_2(int index){	ARCH_WORD binary;	binary = buffer[index].aligned.data.binary[0];	return DES_STD_HASH_2(binary);}static int salt_hash(void *salt){	return DES_STD_HASH_2(*(ARCH_WORD *)salt) & 0x3FF;}static void set_salt(void *salt){	saved_salt = *(ARCH_WORD*)salt;	saved_count = ((ARCH_WORD *)salt)[1];}#endifstatic void set_key(char *key, int index){	char *ptr, *chr;	int pos, word;	unsigned ARCH_WORD block[2];	union {		double dummy;		DES_binary binary;	} aligned;	char chars[8];#if DES_BS	char *final = key;#endif	DES_std_set_key(key);	for (pos = 0, ptr = key; pos < 8 && *ptr; pos++, ptr++);	block[1] = block[0] = 0;	while (*ptr) {		ptr -= 8;		for (word = 0; word < 2; word++)		for (pos = 0; pos < 4; pos++)			block[word] ^= (ARCH_WORD)*ptr++ << (1 + (pos << 3));#if !DES_BS		if (current_salt)			DES_std_set_salt(current_salt = 0);		DES_count = 1;#endif		DES_std_set_block(block[0], block[1]);		DES_std_crypt(DES_KS_current, aligned.binary);		DES_std_get_block(aligned.binary, block);		chr = chars;		for (word = 0; word < 2; word++)		for (pos = 0; pos < 4; pos++) {			*chr++ = 0x80 |				((block[word] >> (1 + (pos << 3))) ^ *ptr);			if (*ptr) ptr++;		}#if DES_BS		final = chars;		if (*ptr)#endif			DES_std_set_key(chars);	}#if DES_BS	strnfcpy(buffer[index].final, final, 8);	keys_changed = 1;#else	memcpy(buffer[index].aligned.data.KS, DES_KS_current, sizeof(DES_KS));#endif	strnfcpy(buffer[index].key, key, PLAINTEXT_LENGTH);}static char *get_key(int index){	static char out[PLAINTEXT_LENGTH + 1];	return strnzcpy(out, buffer[index].key, PLAINTEXT_LENGTH + 1);}#if DES_BSstatic void crypt_all(int count){	int index;	if (keys_changed) {		DES_bs_clear_keys();		for (index = 0; index < count; index++)			DES_bs_set_key(buffer[index].final, index);		keys_changed = 0;	}	DES_bs_crypt(saved_count);}static int cmp_all(void *binary, int count){	return DES_bs_cmp_all((ARCH_WORD *)binary, binary_bits);}static int cmp_one(void *binary, int index){	return DES_bs_cmp_one((ARCH_WORD *)binary, binary_bits, index);}static int cmp_exact(char *source, int index){	return DES_bs_cmp_one(DES_bs_get_binary(source), 64, index);}#elsestatic void crypt_all(int count){	int index;	if (current_salt != saved_salt)		DES_std_set_salt(current_salt = saved_salt);	memset(DES_IV, 0, sizeof(DES_IV));	DES_count = saved_count;	for (index = 0; index < count; index++)		DES_std_crypt(buffer[index].aligned.data.KS,			buffer[index].aligned.data.binary);}static int cmp_all(void *binary, int count){	int index;	for (index = 0; index < count; index++)	if (*(unsigned ARCH_WORD *)binary ==	    (buffer[index].aligned.data.binary[0] & DES_BINARY_MASK))		return 1;	return 0;}static int cmp_one(void *binary, int index){	return *(unsigned ARCH_WORD *)binary ==		(buffer[index].aligned.data.binary[0] & DES_BINARY_MASK);}static int cmp_exact(char *source, int index){	ARCH_WORD *binary;	int word;	binary = DES_std_get_binary(source);	for (word = 0; word < 16 / DES_SIZE; word++)	if ((unsigned ARCH_WORD)binary[word] !=	    (buffer[index].aligned.data.binary[word] & DES_BINARY_MASK))		return 0;	return 1;}#endifstruct fmt_main fmt_BSDI = {	{		FORMAT_LABEL,		FORMAT_NAME,		ALGORITHM_NAME,		BENCHMARK_COMMENT,		PLAINTEXT_LENGTH,		BINARY_SIZE,		SALT_SIZE,		MIN_KEYS_PER_CRYPT,		MAX_KEYS_PER_CRYPT,		tests	}, {		init,		valid,		fmt_default_split,		(void *(*)(char *))#if DES_BS			DES_bs_get_binary,#else			DES_std_get_binary,#endif		salt,		{			binary_hash_0,			binary_hash_1,			binary_hash_2		},		salt_hash,		set_salt,		set_key,		get_key,		crypt_all,		{			get_hash_0,			get_hash_1,			get_hash_2		},		cmp_all,		cmp_one,		cmp_exact	}};

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区在线看| 91女神在线视频| 欧美成人video| 另类的小说在线视频另类成人小视频在线| 9191久久久久久久久久久| 天天色图综合网| 欧美一区在线视频| 精品一区二区三区免费播放| 2021中文字幕一区亚洲| 大白屁股一区二区视频| 亚洲欧美日韩国产综合在线| 欧美亚洲日本一区| 美女久久久精品| 日本一区二区电影| 日本韩国欧美一区| 日本va欧美va精品发布| 日韩欧美中文字幕精品| 成人综合婷婷国产精品久久蜜臀| 综合久久一区二区三区| 欧美年轻男男videosbes| 国产一区视频在线看| 中文字幕一区二区三区精华液| 在线免费观看成人短视频| 美女网站色91| 亚洲丝袜自拍清纯另类| 欧美精品一级二级三级| 国产精品性做久久久久久| 一区二区三区在线视频观看58| 日韩午夜精品电影| av亚洲产国偷v产偷v自拍| 午夜在线电影亚洲一区| 久久久99免费| 欧美日韩一区二区在线观看视频| 黄色日韩三级电影| 亚洲在线中文字幕| 久久久久久久久伊人| 欧美日韩一二区| 国产999精品久久久久久绿帽| 亚洲成人一区在线| 中文字幕高清一区| 欧美一区二区黄| 色婷婷av一区二区三区软件| 精品一区二区三区免费毛片爱| 亚洲综合免费观看高清完整版| 国产亚洲一区二区三区四区| 欧美三级韩国三级日本三斤| 国产麻豆精品95视频| 五月婷婷综合激情| 最新国产の精品合集bt伙计| 26uuu国产一区二区三区| 欧美在线观看视频一区二区| 成人一级片在线观看| 久久国产日韩欧美精品| 性感美女久久精品| 一区二区三区中文免费| 国产精品三级电影| 久久综合九色欧美综合狠狠| 8x8x8国产精品| 欧美亚洲国产bt| 色综合久久九月婷婷色综合| 国产91露脸合集magnet| 国产一区二区三区黄视频 | 久久精品噜噜噜成人88aⅴ| 亚洲男人天堂一区| 国产精品久久久久久久久快鸭| 精品99久久久久久| 日韩一区二区三区视频| 欧美日本在线播放| 欧美唯美清纯偷拍| 色av一区二区| 在线日韩av片| 在线观看成人免费视频| 91黄色激情网站| 在线视频中文字幕一区二区| 色综合久久久久网| 在线观看一区二区视频| 色综合一个色综合| 91精品91久久久中77777| 欧美在线色视频| 欧美色区777第一页| 欧美巨大另类极品videosbest | 日韩精品一区在线观看| 日韩一区二区精品葵司在线| 欧美不卡视频一区| 欧美大片日本大片免费观看| 精品福利一二区| 久久久久久久免费视频了| 日本一区二区在线不卡| 国产精品美女久久久久久久网站| 中文字幕在线不卡一区二区三区 | 日韩欧美一级二级三级| 日韩欧美美女一区二区三区| 精品福利一区二区三区| 国产欧美精品一区| 亚洲天堂av老司机| 亚洲第一电影网| 老司机午夜精品| 国产成人午夜视频| 91美女蜜桃在线| 欧美日韩国产经典色站一区二区三区| 8x8x8国产精品| 国产婷婷精品av在线| 亚洲人成网站精品片在线观看 | 欧美另类一区二区三区| 欧美成人国产一区二区| 国产精品免费人成网站| 亚洲自拍偷拍综合| 麻豆91精品91久久久的内涵| 成人免费福利片| 欧美中文字幕一区二区三区亚洲| 91精品婷婷国产综合久久 | 亚洲欧洲性图库| 午夜婷婷国产麻豆精品| 国产精品一区二区91| 欧美性生活久久| 久久色在线视频| 亚洲综合一二区| 国产伦精品一区二区三区视频青涩| 99久久精品99国产精品 | 欧美三级韩国三级日本三斤| 久久蜜臀精品av| 国产精品乡下勾搭老头1| 色婷婷激情久久| 久久久久久亚洲综合| 亚洲综合成人在线| 国产成人av一区二区三区在线观看| 在线免费精品视频| 中文字幕乱码亚洲精品一区| 日韩黄色在线观看| 色综合久久久久综合99| 久久影院午夜片一区| 亚洲五码中文字幕| 成人免费高清视频| 日韩欧美色电影| 午夜精品久久久久久久蜜桃app| 从欧美一区二区三区| 日韩一级片在线观看| 一区二区久久久久久| 国产盗摄精品一区二区三区在线| 欧美日韩成人一区| 亚洲女子a中天字幕| 粉嫩一区二区三区性色av| 日韩女优电影在线观看| 午夜精品久久久久久久久久久 | 精品一区二区三区久久| 欧美日韩免费一区二区三区| 亚洲欧洲三级电影| 国产99久久久国产精品| 精品噜噜噜噜久久久久久久久试看 | 性感美女极品91精品| 91丝袜美女网| 国产精品久久久久久久午夜片| 韩国av一区二区| 91精品国产色综合久久ai换脸 | 不卡影院免费观看| 久久综合五月天婷婷伊人| 日本伊人色综合网| 欧美丰满嫩嫩电影| 婷婷综合另类小说色区| 欧美日韩高清一区二区三区| 国产精品自拍一区| 欧美成人一区二区三区片免费| 丝袜a∨在线一区二区三区不卡| 日本电影欧美片| 一区二区三区在线免费播放 | 国内精品久久久久影院一蜜桃| 欧美一区二区三区人| 日本中文一区二区三区| 91精品国产综合久久精品app | 精品一区在线看| 日韩精品一区二区三区老鸭窝| 久久99精品久久久久| 精品久久久三级丝袜| 国产精品亚洲视频| 欧美韩国一区二区| 99精品视频一区二区三区| 亚洲欧美日韩综合aⅴ视频| 一本到不卡免费一区二区| 一区二区三区在线视频观看58| 欧美三级视频在线| 日韩精品亚洲一区| 久久人人97超碰com| 成人综合激情网| 一区二区三区四区高清精品免费观看 | 欧美日韩在线三区| 免费观看在线综合| 久久日一线二线三线suv| 成人av在线影院| 亚洲午夜一二三区视频| 日韩一区二区三区视频| 国产精品自产自拍| 亚洲品质自拍视频| 在线观看91精品国产麻豆| 久久草av在线| 国产精品成人免费在线| 欧美日本乱大交xxxxx| 韩国三级电影一区二区| 中文字幕亚洲欧美在线不卡| 欧美人妇做爰xxxⅹ性高电影| 韩国精品在线观看|