⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rdp.c

📁 Linux环境下的远程登陆客户端软件,其采用RDP协议
💻 C
📖 第 1 页 / 共 2 页
字号:
static voidrdp_out_share_caps(STREAM s){	out_uint16_le(s, RDP_CAPSET_SHARE);	out_uint16_le(s, RDP_CAPLEN_SHARE);	out_uint16(s, 0);	/* userid */	out_uint16(s, 0);	/* pad */}/* Output colour cache capability set */static voidrdp_out_colcache_caps(STREAM s){	out_uint16_le(s, RDP_CAPSET_COLCACHE);	out_uint16_le(s, RDP_CAPLEN_COLCACHE);	out_uint16_le(s, 6);	/* cache size */	out_uint16(s, 0);	/* pad */}static uint8 caps_0x0d[] = {	0x01, 0x00, 0x00, 0x00, 0x09, 0x04, 0x00, 0x00,	0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x0C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,	0x00, 0x00, 0x00, 0x00};static uint8 caps_0x0c[] = { 0x01, 0x00, 0x00, 0x00 };static uint8 caps_0x0e[] = { 0x01, 0x00, 0x00, 0x00 };static uint8 caps_0x10[] = {	0xFE, 0x00, 0x04, 0x00, 0xFE, 0x00, 0x04, 0x00,	0xFE, 0x00, 0x08, 0x00, 0xFE, 0x00, 0x08, 0x00,	0xFE, 0x00, 0x10, 0x00, 0xFE, 0x00, 0x20, 0x00,	0xFE, 0x00, 0x40, 0x00, 0xFE, 0x00, 0x80, 0x00,	0xFE, 0x00, 0x00, 0x01, 0x40, 0x00, 0x00, 0x08,	0x00, 0x01, 0x00, 0x01, 0x02, 0x00, 0x00, 0x00};/* Output unknown capability sets */static voidrdp_out_unknown_caps(STREAM s, uint16 id, uint16 length, uint8 * caps){	out_uint16_le(s, id);	out_uint16_le(s, length);	out_uint8p(s, caps, length - 4);}#define RDP5_FLAG 0x0030/* Send a confirm active PDU */static voidrdp_send_confirm_active(void){	STREAM s;	uint32 sec_flags = g_encryption ? (RDP5_FLAG | SEC_ENCRYPT) : RDP5_FLAG;	uint16 caplen =		RDP_CAPLEN_GENERAL + RDP_CAPLEN_BITMAP + RDP_CAPLEN_ORDER +		RDP_CAPLEN_BMPCACHE + RDP_CAPLEN_COLCACHE +		RDP_CAPLEN_ACTIVATE + RDP_CAPLEN_CONTROL +		RDP_CAPLEN_POINTER + RDP_CAPLEN_SHARE +		0x58 + 0x08 + 0x08 + 0x34 /* unknown caps */  +		4 /* w2k fix, why? */ ;	s = sec_init(sec_flags, 6 + 14 + caplen + sizeof(RDP_SOURCE));	out_uint16_le(s, 2 + 14 + caplen + sizeof(RDP_SOURCE));	out_uint16_le(s, (RDP_PDU_CONFIRM_ACTIVE | 0x10));	/* Version 1 */	out_uint16_le(s, (g_mcs_userid + 1001));	out_uint32_le(s, g_rdp_shareid);	out_uint16_le(s, 0x3ea);	/* userid */	out_uint16_le(s, sizeof(RDP_SOURCE));	out_uint16_le(s, caplen);	out_uint8p(s, RDP_SOURCE, sizeof(RDP_SOURCE));	out_uint16_le(s, 0xd);	/* num_caps */	out_uint8s(s, 2);	/* pad */	rdp_out_general_caps(s);	rdp_out_bitmap_caps(s);	rdp_out_order_caps(s);	g_use_rdp5 ? rdp_out_bmpcache2_caps(s) : rdp_out_bmpcache_caps(s);	rdp_out_colcache_caps(s);	rdp_out_activate_caps(s);	rdp_out_control_caps(s);	rdp_out_pointer_caps(s);	rdp_out_share_caps(s);	rdp_out_unknown_caps(s, 0x0d, 0x58, caps_0x0d);	/* international? */	rdp_out_unknown_caps(s, 0x0c, 0x08, caps_0x0c);	rdp_out_unknown_caps(s, 0x0e, 0x08, caps_0x0e);	rdp_out_unknown_caps(s, 0x10, 0x34, caps_0x10);	/* glyph cache? */	s_mark_end(s);	sec_send(s, sec_flags);}/* Process a general capability set */static voidrdp_process_general_caps(STREAM s){	uint16 pad2octetsB;	/* rdp5 flags? */	in_uint8s(s, 10);	in_uint16_le(s, pad2octetsB);	if (!pad2octetsB)		g_use_rdp5 = False;}/* Process a bitmap capability set */static voidrdp_process_bitmap_caps(STREAM s){	uint16 width, height, bpp;	in_uint16_le(s, bpp);	in_uint8s(s, 6);	in_uint16_le(s, width);	in_uint16_le(s, height);	DEBUG(("setting desktop size and bpp to: %dx%dx%d\n", width, height, bpp));	/*	 * The server may limit bpp and change the size of the desktop (for	 * example when shadowing another session).	 */	if (g_server_bpp != bpp)	{		warning("colour depth changed from %d to %d\n", g_server_bpp, bpp);		g_server_bpp = bpp;	}	if (g_width != width || g_height != height)	{		warning("screen size changed from %dx%d to %dx%d\n", g_width, g_height,			width, height);		g_width = width;		g_height = height;		ui_resize_window();	}}/* Process server capabilities */voidrdp_process_server_caps(STREAM s, uint16 length){	int n;	uint8 *next, *start;	uint16 ncapsets, capset_type, capset_length;	start = s->p;	in_uint16_le(s, ncapsets);	in_uint8s(s, 2);	/* pad */	for (n = 0; n < ncapsets; n++)	{		if (s->p > start + length)			return;		in_uint16_le(s, capset_type);		in_uint16_le(s, capset_length);		next = s->p + capset_length - 4;		switch (capset_type)		{			case RDP_CAPSET_GENERAL:				rdp_process_general_caps(s);				break;			case RDP_CAPSET_BITMAP:				rdp_process_bitmap_caps(s);				break;		}		s->p = next;	}}/* Respond to a demand active PDU */static voidprocess_demand_active(STREAM s){	uint8 type;	uint16 len_src_descriptor, len_combined_caps;	in_uint32_le(s, g_rdp_shareid);	in_uint16_le(s, len_src_descriptor);	in_uint16_le(s, len_combined_caps);	in_uint8s(s, len_src_descriptor);	DEBUG(("DEMAND_ACTIVE(id=0x%x)\n", g_rdp_shareid));	rdp_process_server_caps(s, len_combined_caps);	rdp_send_confirm_active();	rdp_send_synchronise();	rdp_send_control(RDP_CTL_COOPERATE);	rdp_send_control(RDP_CTL_REQUEST_CONTROL);	rdp_recv(&type);	/* RDP_PDU_SYNCHRONIZE */	rdp_recv(&type);	/* RDP_CTL_COOPERATE */	rdp_recv(&type);	/* RDP_CTL_GRANT_CONTROL */	rdp_send_input(0, RDP_INPUT_SYNCHRONIZE, 0, ui_get_numlock_state(read_keyboard_state()), 0);	if (g_use_rdp5)	{		rdp_enum_bmpcache2();		rdp_send_fonts(3);	}	else	{		rdp_send_fonts(1);		rdp_send_fonts(2);	}	rdp_recv(&type);	/* RDP_PDU_UNKNOWN 0x28 (Fonts?) */	reset_order_state();}/* Process a colour pointer PDU */voidprocess_colour_pointer_pdu(STREAM s){	uint16 x, y, width, height, cache_idx, masklen, datalen;	uint8 *mask, *data;	HCURSOR cursor;	in_uint16_le(s, cache_idx);	in_uint16_le(s, x);	in_uint16_le(s, y);	in_uint16_le(s, width);	in_uint16_le(s, height);	in_uint16_le(s, masklen);	in_uint16_le(s, datalen);	in_uint8p(s, data, datalen);	in_uint8p(s, mask, masklen);	cursor = ui_create_cursor(x, y, width, height, mask, data);	ui_set_cursor(cursor);	cache_put_cursor(cache_idx, cursor);}/* Process a cached pointer PDU */voidprocess_cached_pointer_pdu(STREAM s){	uint16 cache_idx;	in_uint16_le(s, cache_idx);	ui_set_cursor(cache_get_cursor(cache_idx));}/* Process a system pointer PDU */voidprocess_system_pointer_pdu(STREAM s){	uint16 system_pointer_type;	in_uint16(s, system_pointer_type);	switch (system_pointer_type)	{		case RDP_NULL_POINTER:			ui_set_null_cursor();			break;		default:			unimpl("System pointer message 0x%x\n", system_pointer_type);	}}/* Process a pointer PDU */static voidprocess_pointer_pdu(STREAM s){	uint16 message_type;	uint16 x, y;	in_uint16_le(s, message_type);	in_uint8s(s, 2);	/* pad */	switch (message_type)	{		case RDP_POINTER_MOVE:			in_uint16_le(s, x);			in_uint16_le(s, y);			if (s_check(s))				ui_move_pointer(x, y);			break;		case RDP_POINTER_COLOR:			process_colour_pointer_pdu(s);			break;		case RDP_POINTER_CACHED:			process_cached_pointer_pdu(s);			break;		case RDP_POINTER_SYSTEM:			process_system_pointer_pdu(s);			break;		default:			unimpl("Pointer message 0x%x\n", message_type);	}}/* Process bitmap updates */voidprocess_bitmap_updates(STREAM s){	uint16 num_updates;	uint16 left, top, right, bottom, width, height;	uint16 cx, cy, bpp, Bpp, compress, bufsize, size;	uint8 *data, *bmpdata;	int i;	in_uint16_le(s, num_updates);	for (i = 0; i < num_updates; i++)	{		in_uint16_le(s, left);		in_uint16_le(s, top);		in_uint16_le(s, right);		in_uint16_le(s, bottom);		in_uint16_le(s, width);		in_uint16_le(s, height);		in_uint16_le(s, bpp);		Bpp = (bpp + 7) / 8;		in_uint16_le(s, compress);		in_uint16_le(s, bufsize);		cx = right - left + 1;		cy = bottom - top + 1;		DEBUG(("BITMAP_UPDATE(l=%d,t=%d,r=%d,b=%d,w=%d,h=%d,Bpp=%d,cmp=%d)\n",		       left, top, right, bottom, width, height, Bpp, compress));		if (!compress)		{			int y;			bmpdata = (uint8 *) xmalloc(width * height * Bpp);			for (y = 0; y < height; y++)			{				in_uint8a(s, &bmpdata[(height - y - 1) * (width * Bpp)],					  width * Bpp);			}			ui_paint_bitmap(left, top, cx, cy, width, height, bmpdata);			xfree(bmpdata);			continue;		}		if (compress & 0x400)		{			size = bufsize;		}		else		{			in_uint8s(s, 2);	/* pad */			in_uint16_le(s, size);			in_uint8s(s, 4);	/* line_size, final_size */		}		in_uint8p(s, data, size);		bmpdata = (uint8 *) xmalloc(width * height * Bpp);		if (bitmap_decompress(bmpdata, width, height, data, size, Bpp))		{			ui_paint_bitmap(left, top, cx, cy, width, height, bmpdata);		}		else		{			DEBUG_RDP5(("Failed to decompress data\n"));		}		xfree(bmpdata);	}}/* Process a palette update */voidprocess_palette(STREAM s){	COLOURENTRY *entry;	COLOURMAP map;	HCOLOURMAP hmap;	int i;	in_uint8s(s, 2);	/* pad */	in_uint16_le(s, map.ncolours);	in_uint8s(s, 2);	/* pad */	map.colours = (COLOURENTRY *) xmalloc(sizeof(COLOURENTRY) * map.ncolours);	DEBUG(("PALETTE(c=%d)\n", map.ncolours));	for (i = 0; i < map.ncolours; i++)	{		entry = &map.colours[i];		in_uint8(s, entry->red);		in_uint8(s, entry->green);		in_uint8(s, entry->blue);	}	hmap = ui_create_colourmap(&map);	ui_set_colourmap(hmap);	xfree(map.colours);}/* Process an update PDU */static voidprocess_update_pdu(STREAM s){	uint16 update_type, count;	in_uint16_le(s, update_type);	ui_begin_update();	switch (update_type)	{		case RDP_UPDATE_ORDERS:			in_uint8s(s, 2);	/* pad */			in_uint16_le(s, count);			in_uint8s(s, 2);	/* pad */			process_orders(s, count);			break;		case RDP_UPDATE_BITMAP:			process_bitmap_updates(s);			break;		case RDP_UPDATE_PALETTE:			process_palette(s);			break;		case RDP_UPDATE_SYNCHRONIZE:			break;		default:			unimpl("update %d\n", update_type);	}	ui_end_update();}/* Process a disconnect PDU */voidprocess_disconnect_pdu(STREAM s, uint32 * ext_disc_reason){	in_uint32_le(s, *ext_disc_reason);	DEBUG(("Received disconnect PDU\n"));}/* Process data PDU */static BOOLprocess_data_pdu(STREAM s, uint32 * ext_disc_reason){	uint8 data_pdu_type;	uint8 ctype;	uint16 clen;	uint32 len;	uint32 roff, rlen;	struct stream *ns = &(g_mppc_dict.ns);	in_uint8s(s, 6);	/* shareid, pad, streamid */	in_uint16(s, len);	in_uint8(s, data_pdu_type);	in_uint8(s, ctype);	in_uint16(s, clen);	clen -= 18;	if (ctype & RDP_MPPC_COMPRESSED)	{		if (len > RDP_MPPC_DICT_SIZE)			error("error decompressed packet size exceeds max\n");		if (mppc_expand(s->p, clen, ctype, &roff, &rlen) == -1)			error("error while decompressing packet\n");		//len -= 18;		/* allocate memory and copy the uncompressed data into the temporary stream */		ns->data = (uint8 *) xrealloc(ns->data, rlen);		memcpy((ns->data), (unsigned char *) (g_mppc_dict.hist + roff), rlen);		ns->size = rlen;		ns->end = (ns->data + ns->size);		ns->p = ns->data;		ns->rdp_hdr = ns->p;		s = ns;	}	switch (data_pdu_type)	{		case RDP_DATA_PDU_UPDATE:			process_update_pdu(s);			break;		case RDP_DATA_PDU_CONTROL:			DEBUG(("Received Control PDU\n"));			break;		case RDP_DATA_PDU_SYNCHRONISE:			DEBUG(("Received Sync PDU\n"));			break;		case RDP_DATA_PDU_POINTER:			process_pointer_pdu(s);			break;		case RDP_DATA_PDU_BELL:			ui_bell();			break;		case RDP_DATA_PDU_LOGON:			DEBUG(("Received Logon PDU\n"));			/* User logged on */			break;		case RDP_DATA_PDU_DISCONNECT:			process_disconnect_pdu(s, ext_disc_reason);			return True;		default:			unimpl("data PDU %d\n", data_pdu_type);	}	return False;}/* Process incoming packets *//* nevers gets out of here till app is done */voidrdp_main_loop(BOOL * deactivated, uint32 * ext_disc_reason){	while (rdp_loop(deactivated, ext_disc_reason))		;}/* used in uiports and rdp_main_loop, processes the rdp packets waiting */BOOLrdp_loop(BOOL * deactivated, uint32 * ext_disc_reason){	uint8 type;	BOOL disc = False;	/* True when a disconnect PDU was received */	BOOL cont = True;	STREAM s;	while (cont)	{		s = rdp_recv(&type);		if (s == NULL)			return False;		switch (type)		{			case RDP_PDU_DEMAND_ACTIVE:				process_demand_active(s);				*deactivated = False;				break;			case RDP_PDU_DEACTIVATE:				DEBUG(("RDP_PDU_DEACTIVATE\n"));				*deactivated = True;				break;			case RDP_PDU_DATA:				disc = process_data_pdu(s, ext_disc_reason);				break;			case 0:				break;			default:				unimpl("PDU %d\n", type);		}		if (disc)			return False;		cont = g_next_packet < s->end;	}	return True;}/* Establish a connection up to the RDP layer */BOOLrdp_connect(char *server, uint32 flags, char *domain, char *password,	    char *command, char *directory){	if (!sec_connect(server, g_username))		return False;	rdp_send_logon_info(flags, domain, g_username, password, command, directory);	return True;}/* Disconnect from the RDP layer */voidrdp_disconnect(void){	sec_disconnect();}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -