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

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

?? ecoffice.cpp

?? 橢圓曲線算法改裝
?? CPP
字號:
#include "ECOffice.h"
#include "crc32.h"

//////////////////////////////////////////////
// convert string to bit stream 
// input string and length (not include null-stop), return bit stream 
////////////////////////////////////////////////
INTVECTOR Byte2Bit(const char* str , const int len)
{
	INTVECTOR tmpVec;
	int i, j;
	BYTE *tmp = new BYTE [len];
	for(i = 0 ; i < len; i++)
	{
		tmp[i] = str[i];
		for(j = 0; j < 8; j++)
		{
			if( (tmp[i] << j) & 0x80 )
				tmpVec.push_back(1);
			else
				tmpVec.push_back(0);
		}
	}
	if(tmp != NULL)
	{
		delete tmp;
		tmp = NULL;
	}
	return tmpVec;
}

/***************************************************************************************
		函數功能:		vector轉化為int, 不足位數補0
		參數:
				vec	------------------	vector形式的密碼
				key	------------------	int形式的密碼
				len	------------------	密碼最大長度
		返回值:	
***************************************************************************************/
void vec2int(INTVECTOR vec, unsigned int *key, const int len)
{
	int i, j;
	unsigned int *temp = new unsigned int [len*8];
	for (j = 0, i = len*8-vec.size (); i < len*8; i ++, j ++)
	{
		temp[i] = vec[j];
	}
	i = vec.size ();
	for (i = 0, j = len*8-vec.size (); i < j; i ++)
		temp[i] = 0;
	for (i = 0; i < len; i ++)
	{
		for (key[i] = 0, j = 0; j < 8; j ++)
		{
			key[i] += temp[i*8+j] * pow(2, 8-j-1);
		}
	}
	delete [] temp;
}

/* Return a 32-bit CRC of the contents of the buffer. */
unsigned long crc32(const unsigned int *s, const unsigned int len)
{
	unsigned int i;
	unsigned long crc32val;

	crc32val = 0;
	for (i = 0; i < len; i ++)
	{
		crc32val = crc32_tab[(crc32val ^ s[i]) & 0xff] ^ (crc32val >> 8);
	}
	return crc32val;
}

///////////////////////////////
// 
// Convert decimate number into binary number
// Input: crc	---		decimate number
//		  bin	---		binary number, presented by binary vector
//
void dec2bin(const unsigned long crc, unsigned char *bin)
{
	int i, j;
	double x;
	unsigned char temp[4];
	unsigned long tmp;
	tmp = crc ^ 0xffffffff;

	for (i = 0; i < 4; i ++)
	{
		temp[i] = ((BYTE*)&(tmp))[i];
		for(j = -7; j <= 0; j ++)
		{
			x = floor (temp[i]*pow(2,j));
			bin[i*8+j+7] = (int)fmod(x,2);
		}
	}
}

/***************************************************************************************
				函數功能: 將用戶輸入密碼加密后保存入文件
				參數:
					password	----------------	密碼
					filename	----------------	文件名
***************************************************************************************/
extern "C" _declspec(dllexport) void _stdcall SaveUserPassword(const char *password, const char *filename)
{		//	給VB調用的DLL函數必須加上_stdcall
	try
	{
		int count;
		unsigned long crc = 0;
		INTVECTOR vec;		
		unsigned int *key = new unsigned int [MAX_PASSWORD_LENGTH];	//	二進制密碼
		BYTE *bin = new BYTE [MAX_PASSWORD_LENGTH];	//	crc校驗碼
		FILE *fp;

		if ((fp = fopen(filename, "w+")) != NULL)
		{
			if (*password)
			{
				for (count = 0; password[count] != '\0' && count < MAX_PASSWORD_LENGTH; count ++);

				vec = Byte2Bit(password, count);
				vec2int(vec, key, MAX_PASSWORD_LENGTH);
				crc = crc32(key, MAX_PASSWORD_LENGTH);		//	密碼做校驗
				dec2bin(crc, bin);

				fwrite(bin, sizeof(BYTE), MAX_PASSWORD_LENGTH, fp);
			}
			else	MessageBox(NULL, "無法存儲您的密碼!", "密碼存儲失敗", MB_OK);

			fclose(fp);
		}
		else	MessageBox(NULL, "密碼文件無法創建, 無法存儲您的密碼!", "密碼存儲失敗", MB_OK);

		delete [] key;
		delete [] bin;
		delete fp;
	}
	catch(...)
	{
		MessageBox(NULL, "安裝失敗, 請重新安裝程序!", "未知錯誤", MB_OK);
	}
}

//********************************************************************
//generate EC key modual,2 parameter
//zPrivkeyfile-----------------the path to place generated private key
//zPubkeyfile-----------------the path to place generated public key
//********************************************************************
extern "C" __declspec(dllexport) void _stdcall GenerateECDKey (const char *zPrivkeyfile, const char* zPubkeyfile)
{		//	給VB調用的DLL函數必須加上_stdcall
	try
	{
		GenerateECKey(zPrivkeyfile, zPubkeyfile);
	}
	catch(...)
	{
		MessageBox(NULL, "公私鑰生成失敗, 請重新安裝程序!", "未知錯誤", MB_OK);
	}
}

//******************************************************************************
//generat ECD signfile modual,4 parameter
//zPrivkeyFile--------------------------the path where the pivater key placed
//zOrigFile-----------------------------the path where the origianl file to be signed placed
//zSignFileName-------------------------the path where the signature file to be placed
//zSignFile-----------------------------this parameter be used to pass the sign information
// success return 0 ; or return 1 
//******************************************************************************
extern "C" int _declspec(dllexport) ECDSignFile(const char *zPrivkeyFile,
				 const char *zTempFile,
				 const char *SignFileName,
				 int *zSignFile)
{
	try
	{
		int i;
		unsigned char *sign = new unsigned char [EC_LENGTH];
		unsigned char *binaryData = new unsigned char [EC_BIT];

		ECSignFile(zPrivkeyFile, zTempFile, SignFileName);

		FILE *fp;
		fp = fopen(SignFileName, "r");
		fread(sign, sizeof(unsigned char), EC_BIT, fp);
		fclose(fp);

		binaryData[0]=sign[0] & 0x01;
        zSignFile[0]=binaryData[0];

		//將簽名信息的字符數組轉換成二進制形式
		for(i = 1; i < EC_BIT; i ++)
		{
			binaryData[i]=((sign[i/8]>>(i%8)) & 0x01);
			zSignFile[i] = binaryData[i];
		}

		delete [] sign;
		delete [] binaryData;

		return 0;
	}
	catch(...)
	{
		return 1;
	}
}

//******************************************************************************
//EC verify modual, 4 parameter
//pubkeyfile---------------------------the path where the public key placed
//origFile-----------------------------the path where the original file placed
//signFile-----------------------------the path where the signature file placed
//binaryWm-----------------------------the watermarked info extracted from image be 
//                                     used to verify the oiginal file
//******************************************************************************
extern "C" int _declspec(dllexport) ECDVerifyFile(const char *pubkeyfile,
				    const char *origFile,
				    const char *signFile,
					const int* binaryWm)
{
	try
	{
		int i, j;

		//transform binary array to string
		int temp [EC_LENGTH];
		unsigned char signArray[EC_LENGTH];

		for (i = 0; i < EC_LENGTH; i ++)
			temp[i] = 0;

		for( i = 0; i < EC_LENGTH; i ++ )
		{
			for( j = 0; j <= 7; j ++ )
			{
				if(binaryWm[i*8+j]==1)
					temp[i]=temp[i] | (int)(pow(2, j));
				else
					temp[i]=temp[i] & ~(int)(pow(2, j));
			}
		}

		for (i = 0; i < EC_LENGTH; i ++)
			signArray[i] = temp[i];

		//將得到的字符串存成文件
		FILE *fp;
		fp = fopen(signFile, "w+");
		fwrite(signArray, sizeof(unsigned char), EC_LENGTH, fp);
		fclose(fp);

		if( ECVerifyFile(pubkeyfile, origFile, signFile) )	return 0;
		else	return 1;
	}
	catch(...)
	{
		return -1;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品全国免费观看高清| 亚洲v日本v欧美v久久精品| 中文字幕一区二区三区不卡在线| 国产成人免费视频网站| 欧美亚洲免费在线一区| 久久久精品国产免费观看同学| 99久免费精品视频在线观看| 成人精品免费视频| 成人av在线资源| 欧美一卡二卡三卡| 亚洲一区二区三区四区五区黄| 久久精品国产999大香线蕉| 欧美性受xxxx黑人xyx| 精品视频在线看| 国产精品久久久久久久久动漫| 老司机午夜精品99久久| 激情综合色播五月| 在线电影欧美成精品| 国产日韩欧美亚洲| 综合激情成人伊人| 国产电影精品久久禁18| av动漫一区二区| 国产午夜精品久久| 亚洲乱码国产乱码精品精98午夜 | 欧美日韩视频一区二区| 一区二区中文字幕在线| 一区二区三区美女视频| 99re热这里只有精品免费视频| 91丨porny丨中文| 欧美日韩在线播放三区四区| 日韩写真欧美这视频| 精品久久久三级丝袜| 国产精品区一区二区三| 国产99久久久精品| 国产欧美精品一区aⅴ影院| 国产在线一区二区综合免费视频| 成人免费的视频| 国产精品美女久久福利网站| 亚洲成人三级小说| 国产激情一区二区三区四区| 精品999在线播放| 国产精品亚洲一区二区三区在线 | 欧美日韩一区二区在线观看视频 | 久久精品综合网| 亚洲免费色视频| 91在线小视频| www一区二区| 亚洲综合一区二区| 欧美欧美欧美欧美| 精品亚洲欧美一区| 欧美无人高清视频在线观看| 亚洲国产aⅴ天堂久久| 91精品久久久久久久99蜜桃| 久久成人久久爱| 在线视频中文字幕一区二区| 亚洲一二三四在线观看| 欧美一区二区三区不卡| 国产一区 二区 三区一级| 国产精品麻豆久久久| 在线观看区一区二| 日本不卡在线视频| 欧美三级日韩三级| 美国十次了思思久久精品导航| xfplay精品久久| 91猫先生在线| 自拍偷拍国产亚洲| 在线播放91灌醉迷j高跟美女| 韩国视频一区二区| 日韩亚洲欧美在线观看| 粉嫩一区二区三区在线看| 欧美一区二区美女| 香蕉成人啪国产精品视频综合网| 97se亚洲国产综合自在线不卡| 国产丝袜欧美中文另类| 欧美日韩一区二区欧美激情| 国产一区激情在线| 天使萌一区二区三区免费观看| 欧美成人精品1314www| 91色porny蝌蚪| 亚洲视频狠狠干| 精品国一区二区三区| 97精品超碰一区二区三区| 国产精品欧美久久久久一区二区| 欧美日高清视频| aaa欧美色吧激情视频| 国产精品国产自产拍高清av王其 | 性感美女久久精品| 国产精品―色哟哟| 欧美大片拔萝卜| 欧美色图在线观看| 成人黄色在线网站| 国内成人免费视频| 免费看欧美女人艹b| 在线播放中文字幕一区| 色综合久久88色综合天天免费| 国产乱码精品一区二区三区五月婷| 欧美不卡123| 欧美日韩精品一区视频| 91免费在线播放| 亚洲午夜电影在线观看| 日韩一级黄色片| 国产精品一区二区久久精品爱涩 | 亚洲国产欧美在线| 国产精品电影一区二区三区| 91在线观看免费视频| 国产成人在线色| 久草中文综合在线| 欧美激情综合网| 久久久久久久免费视频了| 日韩美女视频在线| 日韩欧美一区二区视频| 欧美放荡的少妇| 国产99一区视频免费| 国产xxx精品视频大全| 国产成人综合亚洲网站| 亚洲精品视频在线观看网站| 欧美国产丝袜视频| 国产精品麻豆一区二区| 欧美美女一区二区三区| 欧美精品 日韩| 777亚洲妇女| 日韩一卡二卡三卡| 99久久精品久久久久久清纯| 成人app下载| 美女视频黄久久| 久久99国产精品免费| 亚洲视频免费观看| 久久久精品免费免费| 欧美经典一区二区| 亚洲丝袜美腿综合| 亚洲夂夂婷婷色拍ww47| 欧美国产欧美亚州国产日韩mv天天看完整 | 5858s免费视频成人| 欧美一区二区国产| 久久精品视频网| 欧美一区日本一区韩国一区| 日韩欧美久久一区| 日本一区二区三区视频视频| 欧美丰满嫩嫩电影| 久久久精品欧美丰满| 亚洲人成7777| 欧美日韩国产一级| 高清成人在线观看| 欧美亚洲愉拍一区二区| 日韩午夜激情av| 国产精品区一区二区三| 亚洲成人动漫在线观看| 亚洲人成小说网站色在线| 久久久久亚洲综合| 欧美一级高清片| 欧美日韩成人综合| 国产婷婷一区二区| 久久这里只有精品首页| 亚洲色图制服丝袜| 中文字幕一区二区三区不卡 | 欧美日韩视频在线观看一区二区三区| 欧美一区二区成人| 69堂成人精品免费视频| 国产日韩在线不卡| 亚洲成av人在线观看| 亚洲国产精品久久久久秋霞影院 | xfplay精品久久| 夜夜嗨av一区二区三区四季av | 亚洲成人av电影在线| 亚洲精品一二三| 国内精品免费**视频| 国产在线国偷精品免费看| 国产真实乱对白精彩久久| 欧美日韩久久久久久| 国产精品久久三| 综合av第一页| 亚洲综合清纯丝袜自拍| 国产91精品精华液一区二区三区 | 日韩vs国产vs欧美| 99re热这里只有精品视频| 91免费在线看| 欧美三级中文字幕| 国产精品电影院| 国产精品一区二区不卡| 91精品国产麻豆| 亚洲电影中文字幕在线观看| 99这里都是精品| 在线视频国内自拍亚洲视频| 欧美国产精品一区二区三区| 国产在线麻豆精品观看| 日韩一区二区免费在线电影| 午夜在线成人av| 国精产品一区一区三区mba桃花| 欧美日韩综合在线免费观看| 自拍av一区二区三区| 风间由美一区二区三区在线观看 | 久久国产精品一区二区| 国产成人亚洲精品狼色在线| 日韩视频国产视频| 日韩电影在线观看一区| 国产精品一区免费在线观看| 精品国产乱码久久久久久老虎 | 99视频一区二区三区| 中文字幕第一区| 波多野结衣中文一区|