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

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

?? secure.c

?? LInux 下的遠程桌面工具 Rdesktop
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* -*- c-basic-offset: 8 -*-   rdesktop: A Remote Desktop Protocol client.   Protocol services - RDP encryption and licensing   Copyright (C) Matthew Chapman 1999-2007   This program is free software; you can redistribute it and/or modify   it under the terms of the GNU General Public License as published by   the Free Software Foundation; either version 2 of the License, or   (at your option) any later version.   This program is distributed in the hope that it will be useful,   but WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the   GNU General Public License for more details.   You should have received a copy of the GNU General Public License   along with this program; if not, write to the Free Software   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.*/#include "rdesktop.h"#include "ssl.h"extern char g_hostname[16];extern int g_width;extern int g_height;extern unsigned int g_keylayout;extern int g_keyboard_type;extern int g_keyboard_subtype;extern int g_keyboard_functionkeys;extern RD_BOOL g_encryption;extern RD_BOOL g_licence_issued;extern RD_BOOL g_use_rdp5;extern RD_BOOL g_console_session;extern int g_server_depth;extern VCHANNEL g_channels[];extern unsigned int g_num_channels;static int g_rc4_key_len;static SSL_RC4 g_rc4_decrypt_key;static SSL_RC4 g_rc4_encrypt_key;static uint32 g_server_public_key_len;static uint8 g_sec_sign_key[16];static uint8 g_sec_decrypt_key[16];static uint8 g_sec_encrypt_key[16];static uint8 g_sec_decrypt_update_key[16];static uint8 g_sec_encrypt_update_key[16];static uint8 g_sec_crypted_random[SEC_MAX_MODULUS_SIZE];uint16 g_server_rdp_version = 0;/* These values must be available to reset state - Session Directory */static int g_sec_encrypt_use_count = 0;static int g_sec_decrypt_use_count = 0;/* * I believe this is based on SSLv3 with the following differences: *  MAC algorithm (5.2.3.1) uses only 32-bit length in place of seq_num/type/length fields *  MAC algorithm uses SHA1 and MD5 for the two hash functions instead of one or other *  key_block algorithm (6.2.2) uses 'X', 'YY', 'ZZZ' instead of 'A', 'BB', 'CCC' *  key_block partitioning is different (16 bytes each: MAC secret, decrypt key, encrypt key) *  encryption/decryption keys updated every 4096 packets * See http://wp.netscape.com/eng/ssl3/draft302.txt *//* * 48-byte transformation used to generate master secret (6.1) and key material (6.2.2). * Both SHA1 and MD5 algorithms are used. */voidsec_hash_48(uint8 * out, uint8 * in, uint8 * salt1, uint8 * salt2, uint8 salt){	uint8 shasig[20];	uint8 pad[4];	SSL_SHA1 sha1;	SSL_MD5 md5;	int i;	for (i = 0; i < 3; i++)	{		memset(pad, salt + i, i + 1);		ssl_sha1_init(&sha1);		ssl_sha1_update(&sha1, pad, i + 1);		ssl_sha1_update(&sha1, in, 48);		ssl_sha1_update(&sha1, salt1, 32);		ssl_sha1_update(&sha1, salt2, 32);		ssl_sha1_final(&sha1, shasig);		ssl_md5_init(&md5);		ssl_md5_update(&md5, in, 48);		ssl_md5_update(&md5, shasig, 20);		ssl_md5_final(&md5, &out[i * 16]);	}}/* * 16-byte transformation used to generate export keys (6.2.2). */voidsec_hash_16(uint8 * out, uint8 * in, uint8 * salt1, uint8 * salt2){	SSL_MD5 md5;	ssl_md5_init(&md5);	ssl_md5_update(&md5, in, 16);	ssl_md5_update(&md5, salt1, 32);	ssl_md5_update(&md5, salt2, 32);	ssl_md5_final(&md5, out);}/* Reduce key entropy from 64 to 40 bits */static voidsec_make_40bit(uint8 * key){	key[0] = 0xd1;	key[1] = 0x26;	key[2] = 0x9e;}/* Generate encryption keys given client and server randoms */static voidsec_generate_keys(uint8 * client_random, uint8 * server_random, int rc4_key_size){	uint8 pre_master_secret[48];	uint8 master_secret[48];	uint8 key_block[48];	/* Construct pre-master secret */	memcpy(pre_master_secret, client_random, 24);	memcpy(pre_master_secret + 24, server_random, 24);	/* Generate master secret and then key material */	sec_hash_48(master_secret, pre_master_secret, client_random, server_random, 'A');	sec_hash_48(key_block, master_secret, client_random, server_random, 'X');	/* First 16 bytes of key material is MAC secret */	memcpy(g_sec_sign_key, key_block, 16);	/* Generate export keys from next two blocks of 16 bytes */	sec_hash_16(g_sec_decrypt_key, &key_block[16], client_random, server_random);	sec_hash_16(g_sec_encrypt_key, &key_block[32], client_random, server_random);	if (rc4_key_size == 1)	{		DEBUG(("40-bit encryption enabled\n"));		sec_make_40bit(g_sec_sign_key);		sec_make_40bit(g_sec_decrypt_key);		sec_make_40bit(g_sec_encrypt_key);		g_rc4_key_len = 8;	}	else	{		DEBUG(("rc_4_key_size == %d, 128-bit encryption enabled\n", rc4_key_size));		g_rc4_key_len = 16;	}	/* Save initial RC4 keys as update keys */	memcpy(g_sec_decrypt_update_key, g_sec_decrypt_key, 16);	memcpy(g_sec_encrypt_update_key, g_sec_encrypt_key, 16);	/* Initialise RC4 state arrays */	ssl_rc4_set_key(&g_rc4_decrypt_key, g_sec_decrypt_key, g_rc4_key_len);	ssl_rc4_set_key(&g_rc4_encrypt_key, g_sec_encrypt_key, g_rc4_key_len);}static uint8 pad_54[40] = {	54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54,	54, 54, 54,	54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54,	54, 54, 54};static uint8 pad_92[48] = {	92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92,	92, 92, 92, 92, 92, 92, 92,	92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92, 92,	92, 92, 92, 92, 92, 92, 92};/* Output a uint32 into a buffer (little-endian) */voidbuf_out_uint32(uint8 * buffer, uint32 value){	buffer[0] = (value) & 0xff;	buffer[1] = (value >> 8) & 0xff;	buffer[2] = (value >> 16) & 0xff;	buffer[3] = (value >> 24) & 0xff;}/* Generate a MAC hash (5.2.3.1), using a combination of SHA1 and MD5 */voidsec_sign(uint8 * signature, int siglen, uint8 * session_key, int keylen, uint8 * data, int datalen){	uint8 shasig[20];	uint8 md5sig[16];	uint8 lenhdr[4];	SSL_SHA1 sha1;	SSL_MD5 md5;	buf_out_uint32(lenhdr, datalen);	ssl_sha1_init(&sha1);	ssl_sha1_update(&sha1, session_key, keylen);	ssl_sha1_update(&sha1, pad_54, 40);	ssl_sha1_update(&sha1, lenhdr, 4);	ssl_sha1_update(&sha1, data, datalen);	ssl_sha1_final(&sha1, shasig);	ssl_md5_init(&md5);	ssl_md5_update(&md5, session_key, keylen);	ssl_md5_update(&md5, pad_92, 48);	ssl_md5_update(&md5, shasig, 20);	ssl_md5_final(&md5, md5sig);	memcpy(signature, md5sig, siglen);}/* Update an encryption key */static voidsec_update(uint8 * key, uint8 * update_key){	uint8 shasig[20];	SSL_SHA1 sha1;	SSL_MD5 md5;	SSL_RC4 update;	ssl_sha1_init(&sha1);	ssl_sha1_update(&sha1, update_key, g_rc4_key_len);	ssl_sha1_update(&sha1, pad_54, 40);	ssl_sha1_update(&sha1, key, g_rc4_key_len);	ssl_sha1_final(&sha1, shasig);	ssl_md5_init(&md5);	ssl_md5_update(&md5, update_key, g_rc4_key_len);	ssl_md5_update(&md5, pad_92, 48);	ssl_md5_update(&md5, shasig, 20);	ssl_md5_final(&md5, key);	ssl_rc4_set_key(&update, key, g_rc4_key_len);	ssl_rc4_crypt(&update, key, key, g_rc4_key_len);	if (g_rc4_key_len == 8)		sec_make_40bit(key);}/* Encrypt data using RC4 */static voidsec_encrypt(uint8 * data, int length){	if (g_sec_encrypt_use_count == 4096)	{		sec_update(g_sec_encrypt_key, g_sec_encrypt_update_key);		ssl_rc4_set_key(&g_rc4_encrypt_key, g_sec_encrypt_key, g_rc4_key_len);		g_sec_encrypt_use_count = 0;	}	ssl_rc4_crypt(&g_rc4_encrypt_key, data, data, length);	g_sec_encrypt_use_count++;}/* Decrypt data using RC4 */voidsec_decrypt(uint8 * data, int length){	if (g_sec_decrypt_use_count == 4096)	{		sec_update(g_sec_decrypt_key, g_sec_decrypt_update_key);		ssl_rc4_set_key(&g_rc4_decrypt_key, g_sec_decrypt_key, g_rc4_key_len);		g_sec_decrypt_use_count = 0;	}	ssl_rc4_crypt(&g_rc4_decrypt_key, data, data, length);	g_sec_decrypt_use_count++;}/* Perform an RSA public key encryption operation */static voidsec_rsa_encrypt(uint8 * out, uint8 * in, int len, uint32 modulus_size, uint8 * modulus,		uint8 * exponent){	ssl_rsa_encrypt(out, in, len, modulus_size, modulus, exponent);}/* Initialise secure transport packet */STREAMsec_init(uint32 flags, int maxlen){	int hdrlen;	STREAM s;	if (!g_licence_issued)		hdrlen = (flags & SEC_ENCRYPT) ? 12 : 4;	else		hdrlen = (flags & SEC_ENCRYPT) ? 12 : 0;	s = mcs_init(maxlen + hdrlen);	s_push_layer(s, sec_hdr, hdrlen);	return s;}/* Transmit secure transport packet over specified channel */voidsec_send_to_channel(STREAM s, uint32 flags, uint16 channel){	int datalen;#ifdef WITH_SCARD	scard_lock(SCARD_LOCK_SEC);#endif	s_pop_layer(s, sec_hdr);	if (!g_licence_issued || (flags & SEC_ENCRYPT))		out_uint32_le(s, flags);	if (flags & SEC_ENCRYPT)	{		flags &= ~SEC_ENCRYPT;		datalen = s->end - s->p - 8;#if WITH_DEBUG		DEBUG(("Sending encrypted packet:\n"));		hexdump(s->p + 8, datalen);#endif		sec_sign(s->p, 8, g_sec_sign_key, g_rc4_key_len, s->p + 8, datalen);		sec_encrypt(s->p + 8, datalen);	}	mcs_send_to_channel(s, channel);#ifdef WITH_SCARD	scard_unlock(SCARD_LOCK_SEC);#endif}/* Transmit secure transport packet */voidsec_send(STREAM s, uint32 flags){	sec_send_to_channel(s, flags, MCS_GLOBAL_CHANNEL);}/* Transfer the client random to the server */static voidsec_establish_key(void){	uint32 length = g_server_public_key_len + SEC_PADDING_SIZE;	uint32 flags = SEC_CLIENT_RANDOM;	STREAM s;	s = sec_init(flags, length + 4);	out_uint32_le(s, length);	out_uint8p(s, g_sec_crypted_random, g_server_public_key_len);	out_uint8s(s, SEC_PADDING_SIZE);	s_mark_end(s);	sec_send(s, flags);}/* Output connect initial data blob */static voidsec_out_mcs_data(STREAM s){	int hostlen = 2 * strlen(g_hostname);	int length = 158 + 76 + 12 + 4;	unsigned int i;	if (g_num_channels > 0)		length += g_num_channels * 12 + 8;	if (hostlen > 30)		hostlen = 30;	/* Generic Conference Control (T.124) ConferenceCreateRequest */	out_uint16_be(s, 5);	out_uint16_be(s, 0x14);	out_uint8(s, 0x7c);	out_uint16_be(s, 1);	out_uint16_be(s, (length | 0x8000));	/* remaining length */	out_uint16_be(s, 8);	/* length? */	out_uint16_be(s, 16);	out_uint8(s, 0);	out_uint16_le(s, 0xc001);	out_uint8(s, 0);	out_uint32_le(s, 0x61637544);	/* OEM ID: "Duca", as in Ducati. */	out_uint16_be(s, ((length - 14) | 0x8000));	/* remaining length */	/* Client information */	out_uint16_le(s, SEC_TAG_CLI_INFO);	out_uint16_le(s, 212);	/* length */	out_uint16_le(s, g_use_rdp5 ? 4 : 1);	/* RDP version. 1 == RDP4, 4 == RDP5. */	out_uint16_le(s, 8);	out_uint16_le(s, g_width);	out_uint16_le(s, g_height);	out_uint16_le(s, 0xca01);	out_uint16_le(s, 0xaa03);	out_uint32_le(s, g_keylayout);	out_uint32_le(s, 2600);	/* Client build. We are now 2600 compatible :-) */	/* Unicode name of client, padded to 32 bytes */	rdp_out_unistr(s, g_hostname, hostlen);	out_uint8s(s, 30 - hostlen);	/* See	   http://msdn.microsoft.com/library/default.asp?url=/library/en-us/wceddk40/html/cxtsksupportingremotedesktopprotocol.asp */	out_uint32_le(s, g_keyboard_type);	out_uint32_le(s, g_keyboard_subtype);	out_uint32_le(s, g_keyboard_functionkeys);	out_uint8s(s, 64);	/* reserved? 4 + 12 doublewords */	out_uint16_le(s, 0xca01);	/* colour depth? */	out_uint16_le(s, 1);	out_uint32(s, 0);	out_uint8(s, g_server_depth);	out_uint16_le(s, 0x0700);	out_uint8(s, 0);	out_uint32_le(s, 1);	out_uint8s(s, 64);	/* End of client info */	out_uint16_le(s, SEC_TAG_CLI_4);	out_uint16_le(s, 12);	out_uint32_le(s, g_console_session ? 0xb : 9);	out_uint32(s, 0);	/* Client encryption settings */	out_uint16_le(s, SEC_TAG_CLI_CRYPT);	out_uint16_le(s, 12);	/* length */	out_uint32_le(s, g_encryption ? 0x3 : 0);	/* encryption supported, 128-bit supported */	out_uint32(s, 0);	/* Unknown */	DEBUG_RDP5(("g_num_channels is %d\n", g_num_channels));	if (g_num_channels > 0)	{		out_uint16_le(s, SEC_TAG_CLI_CHANNELS);		out_uint16_le(s, g_num_channels * 12 + 8);	/* length */		out_uint32_le(s, g_num_channels);	/* number of virtual channels */		for (i = 0; i < g_num_channels; i++)		{			DEBUG_RDP5(("Requesting channel %s\n", g_channels[i].name));			out_uint8a(s, g_channels[i].name, 8);			out_uint32_be(s, g_channels[i].flags);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩综合一区二区| 在线精品亚洲一区二区不卡| 成人av电影在线观看| 欧美日韩一区二区三区四区五区| 日韩欧美一区二区久久婷婷| 亚洲国产成人在线| 蜜臀av一级做a爰片久久| 91国产免费看| 中文在线免费一区三区高中清不卡| 日韩1区2区日韩1区2区| 色成年激情久久综合| 久久精品夜色噜噜亚洲aⅴ| 亚洲h精品动漫在线观看| 91理论电影在线观看| 国产婷婷一区二区| 久久国产精品色| 欧美乱妇一区二区三区不卡视频| 成人免费视频在线观看| 国产精品69毛片高清亚洲| 欧美一区二区精美| 亚洲国产裸拍裸体视频在线观看乱了 | 成人免费不卡视频| 日韩一区二区精品| 亚洲国产精品天堂| 欧洲色大大久久| 亚洲视频小说图片| 波多野结衣亚洲一区| 久久精品一区二区| 国产一区二区0| 精品国产乱码久久久久久浪潮| 日韩激情视频在线观看| 欧美三级一区二区| 亚洲成a人片综合在线| 欧洲精品在线观看| 一区二区三区av电影| 91黄视频在线观看| 亚洲v日本v欧美v久久精品| 在线看国产一区| 亚洲国产视频一区| 91精品婷婷国产综合久久性色| 午夜久久电影网| 欧美狂野另类xxxxoooo| 日本欧美一区二区三区乱码| 在线成人高清不卡| 久久国产精品99精品国产| 欧美成人性战久久| 国产盗摄精品一区二区三区在线| 久久久久久久综合日本| 高清shemale亚洲人妖| 国产精品麻豆欧美日韩ww| gogo大胆日本视频一区| 一区二区在线观看免费视频播放 | 国产精品私人自拍| 91视频一区二区| 亚洲成a人v欧美综合天堂| 日韩女优电影在线观看| 国产福利91精品一区二区三区| 国产精品久久久久一区| 91久久精品国产91性色tv| 婷婷开心激情综合| 久久亚洲综合色| 色婷婷综合久久久| 日本不卡1234视频| 国产清纯美女被跳蛋高潮一区二区久久w| 高清不卡一区二区| 天天亚洲美女在线视频| 欧美大度的电影原声| 99国内精品久久| 日本中文一区二区三区| 久久精品亚洲精品国产欧美| 欧美在线你懂得| 国内精品写真在线观看| 亚洲精品成人悠悠色影视| 日韩欧美中文字幕一区| 99久久综合狠狠综合久久| 免费不卡在线视频| 日韩伦理电影网| 精品国产乱码久久久久久闺蜜 | 韩国精品一区二区| 亚洲三级在线免费观看| 欧美成人一区二区| 在线观看视频一区| 国产99久久久国产精品潘金| 亚洲成av人综合在线观看| 国产精品午夜春色av| 日韩一区二区在线免费观看| 95精品视频在线| 国产美女在线精品| 日本在线不卡视频| 夜夜精品浪潮av一区二区三区| 精品国产伦一区二区三区观看方式 | 国产成人免费高清| 免费观看一级特黄欧美大片| 夜夜爽夜夜爽精品视频| 国产精品乱码久久久久久| 欧美成人福利视频| 欧美电影一区二区| 日本高清不卡视频| va亚洲va日韩不卡在线观看| 久久91精品久久久久久秒播| 亚洲综合丁香婷婷六月香| 中文字幕第一区第二区| 久久婷婷国产综合精品青草| 91.com在线观看| 欧美日韩在线三区| 色94色欧美sute亚洲线路一久| 国产成人a级片| 国产在线国偷精品产拍免费yy| 久久精品72免费观看| 石原莉奈在线亚洲二区| 亚洲高清一区二区三区| 亚洲电影中文字幕在线观看| 亚洲免费观看高清在线观看| 成人欧美一区二区三区视频网页 | 激情综合网最新| 久久精品国产一区二区| 日韩不卡在线观看日韩不卡视频| 亚洲成a人v欧美综合天堂| 亚洲www啪成人一区二区麻豆 | 国产精品不卡在线| 国产精品久久久久aaaa樱花| 日韩一区有码在线| 亚洲精品日韩综合观看成人91| 亚洲人亚洲人成电影网站色| 亚洲色图一区二区| 亚洲午夜久久久久久久久久久| 亚洲高清免费观看 | 欧美精品粉嫩高潮一区二区| 欧美影院一区二区| 7878成人国产在线观看| 欧美成人女星排行榜| 久久精品综合网| 中文字幕一区二区三区在线观看| 日韩一区欧美小说| 亚洲成人av一区二区| 美女看a上一区| 国产不卡免费视频| 91一区一区三区| 欧美电影一区二区| 久久色成人在线| 一区精品在线播放| 亚洲成人精品一区二区| 麻豆精品视频在线观看视频| 国产传媒一区在线| 91福利社在线观看| 精品福利二区三区| 亚洲视频一二三区| 免费在线观看一区二区三区| 岛国一区二区在线观看| 在线精品国精品国产尤物884a| 日韩免费一区二区| 一区二区中文字幕在线| 日本欧美一区二区三区| www.欧美亚洲| 欧美一区二区免费| 国产精品国产三级国产专播品爱网 | 日本视频一区二区三区| 国产99久久久国产精品免费看 | 成人激情动漫在线观看| 欧美日韩国产123区| 国产亚洲欧美日韩俺去了| 亚洲综合激情另类小说区| 国产自产v一区二区三区c| 色天使色偷偷av一区二区| 精品国产一二三| 亚洲一级二级在线| 国产成人免费视频| 日韩精品一区二区三区在线播放 | av电影在线不卡| 日韩美女一区二区三区四区| 亚洲人精品午夜| 国产福利一区二区三区视频在线 | 性欧美大战久久久久久久久| 国产成人综合视频| 日韩一区二区三区四区五区六区| 中文字幕在线观看不卡视频| 精一区二区三区| 欧美福利视频一区| 亚洲另类中文字| 成人av网址在线观看| 日韩精品一区二区三区视频播放| 亚洲一区二区三区在线| 欧美美女一区二区| 亚洲三级理论片| 国产aⅴ综合色| 国产亚洲成aⅴ人片在线观看| 日韩av一区二区在线影视| 欧美中文字幕不卡| 亚洲在线视频一区| 91天堂素人约啪| 成人免费小视频| 99久久久久久| 亚洲色图一区二区三区| 成人免费看视频| 国产精品美日韩| 成人激情午夜影院| 国产精品久久久久天堂| 成人免费毛片app| 亚洲欧洲精品一区二区精品久久久| 国产乱子伦视频一区二区三区|