Alt-Tab in Citrix XenApp Remote Desktop

A number of enterprise health systems allow access to a shared EMR virtual server via XenApp.  It’s a nice way of separating concerns and enforcing security, however, there are a few configuration drawbacks.  One issue I ran into was the lack of windows quick-key functionality in remote windows desktops hosted on a XenApp server.  There is a solution though.  See this link for more info.  I run a windows 7 64 bit host system, so I needed to change the registry value at:

HKEY_CURRENT_USER\SOFTWARE\Wow6432Node\Citrix\ICA Client\Engine\Lockdown Profiles\All Regions\Lockdown\Virtual Channels\Keyboard


to equal “Remote” for Alt-Tab to work correctly on my system.  The value was blank prior to me adding the text “Remote”.

Posted in networking, Virtualization, Windows, Xen | Leave a comment

RDP tunneling

The Microsoft terminal server client and its associated Remote Desktop Protocol (RDP) is definitely one of the few reasons I still develop on a windows system. In many ways it’s a very clean and efficient protocol that just plain works. But often I’ve found myself behind corporate routers that have blocked the rdp ports (i.e. 3389). Because of this issue I have had to resort to tunneling the rdp traffic over ports that are not blocked by corporate routers.  Also, since RDP isn’t secure, I needed a way to encrypt my remote sessions.  The steps below explain how to tunnel rdp traffic over ssh’s ports (usually port 22).  To do this you’ll need some cheap hardware, free software, networking knowledge, and time.


  1. A home network router with your/the ssh port forwarded to a machine in your home network.  The machine you forward to will be called the ssh server.
  2. A machine in your home network that is running an ssh server to accept the forwarded ssh traffic.  Alternatively, if you have a dd-wrt router, your router can function as the ssh server.
  3. A windows machine on your home network with its remote desktop server configured to accept clients.  This can be the ssh server machine, but I would recommend having a ssh server that is distinct from the windows/rdp machine.
  4. A basic understanding of network forwarding and protocols.  A bonus would be if you have linux/unix experience.


  1. If these above configurations are in place, then the next step is to install putty, or  a similar ssh client, on your work/remote windows machine.   If you’ve never heard of Putty, it’s a bit like a swiss army knife for network traffic manipulation, and definitely work checking out (see:
  2. Set up a connection to your home network.  This is done by entering your home ip address (i.e. the ip address of the machine running your remote ssh server) in the uppermost putty text box. Alternatively, you can just enter a host/domain name if appropriate dns resolution exists (see or for more info)
  3. Configure the tunneling portion of the connection.  This is done by going exploring/expanding the Category tree in putty’s left most window to reveal the Connection–>SSH–>Tunneling options (See image below).  I tend to use a local port 3391 for the connection and rdps default port for the remote connection (3389).  Notice that I’m forwarding my connection to a another computer in my local network (  This could be any computer in my local network running windows with rdp enabled.  Click the “Add” button to add your tunnel/forward to the connection.
  4. Click on Session in the category tree to get back to the home screen.  Give your connection a name by typing a name in the Saved Sessions text box.  In the image below I’ve named the connection “twinoaks”.
  5. Click open connection and supply the required credentials when prompted.  I strongly suggest this connection be secured by something more than a password.  Putty does allow for RSA public-private key authentication.  More info on authentication with putty can be found here (link to U of Alberta site).  Once the connection/tunnel is established you should be forwarding all traffic on port 3391 to your ssh port (likely 22)
  6. Establish your rdp connection using Start–> Run–>mstsc–> type “localhost:3391″ into the dialog box.
  7. If all goes well you’ll be looking at your remote computer ( in my case) and your connection will be securely tunneled over ssh.
Posted in networking, Windows | Leave a comment

Citrix Receiver (XenApp) and multiple monitors

Last year I took a job within the Valley Health System  (VHS, Shenandoah Valley, VA) and VHS uses Citrix XenApp very  heavily for their clinical applications .  I really like the feature set provided by XenApp, but I could never get the remote desktop protocol (aka. mstsc or rdp) to work over XenApp when I was using more than one monitor.  Each time I would try to connect to a remote machine I would get a dialog box/window stating that 0% of my remote session had been downloaded.  I searched every internet forum I could find for a solution, but no solution could be had.  I even created a support ticket with citrix.  No solution with this route either.  Then I got lucky.  For some reason I noticed that if I changed my primary monitor to be the left-most monitor, everything just worked.  Not sure what the underlying problem was, but this has worked for a number of my dual/triple monitor setups .

Posted in networking, Virtualization, Windows, Xen | Tagged | Leave a comment