Product Reviews

Secure Sessions for Windows

SecureShell is an implementation of SSH for Windows


A primary problem in the Unix world remote access is that there is no real encryption to protect the user's session by default. So, in 1995, a company called SSH Communications Security created a client-server protocol to overcome this problem. SSH allows users to login remotely to a Unix box. SSH creates a security structure that effectively replaces the DARPA command set (ftp, tftp, and telnet) and the Berkeley remote commands (rsh, rlogin, and rcp) with a client-server application. Although there are plenty of SSH clients for different platforms (including Windows) there aren't many SSH daemons (the server side of the equation) for Windows servers.

Count Pragma Systems' SecureShell as one of the few. SecureShell conforms to SSH1 and SSH2, which allows for secure connections across a public network. The SSHD (secure shell daemon) process accepts requests from any SSH client, regardless of platform, and provides sessions remotely. The product also ships with an SSH client for all Win32 platforms. Now since this tool provides services to Windows NT/2000 that are Unix-oriented, I will refer to these services often as daemons. I hope I don't scare the Microsoft acolytes too much. Just know that a daemon in Unix is synonymous to a service in NT.

SecureShell runs initially as an InetD (Internet Daemon) service, listening for requests on port 22 (by default; you can also customize this port) to launch other daemons, such as SSH. When a call comes in to establish a secure shell, InetD spawns SSHD, negotiates the connection using encryption and presents the user with a logon prompt. The logons tie into NTLM/Kerberos, so there is no need to remember additional passwords. After authentication, the user is greeted by a command prompt, and can proceed with their work.

SecureShell performs port forwarding so other protocols, like SMTP and POP, can be facilitated securely. This allows you to route all your traffic through one secured port through the firewall. This is similar to the way SOCKS works, except you get encryption along with it. You can use this product to build quick VPN solutions, capable of providing a secure extranet. If you're worried about someone sniffing your packets, and then performing attacks such as Man In The Middle (MITM), intercept and spoofing, this product will stop them cold.

On the server side, there are plenty of nifty GUI tools that you can use to configure this product. You can configure daemons in much the same way as you do in IIS. This means you can filter IPs, change ports, define users, and create profiles. SecureShell supports multiple connections from multiple users and you can manage all of these sessions to your InetD and find out who is connected to your server.

So how does SecureShell compare with the competition? On the upside, SecureShell is a standardized implementation of SSH. It's cost competitive with other commercial offerings and is featured enough to use in a lot of different situations. It's very easy to use. Literally install the program, create your keys and you're done.

SecureShell is cross-platform. You can connect to a Windows machine from a SSH client on Solaris or use the client from Windows to connect to a FreeBSD sshd. Expanding on this, you can create simple SSH VPN's with SecureShell. This serves as an alternative to IPSec, which although more functional, can be much more complex. SecureShell is very easy to use.

On the downside, you need to worry about key management. SecureShell doesn't have much in the line of information regarding importing and exporting keys, which tells me that this probably will be a sore spot. Even if you have a current RSA/x.509 Certificate Server in place, you must generate your own key sets for SecureShell.

Also, SecureShell is not free. There is an open version of SSH called OpenSSH that does the same thing, with implementations for many platforms including Win32. Of course, you get the support you pay for.

Windows 2000 also adds functionality for IPSec right out of the box. Although IPSec is harder to wield than SSH, wizards make it pretty easy to get ramped up right away with IPSec. This means you have to want to use SSH. But this is a nice product for NT 4.0.

SecureShell is a command line only product. Some implementations of SSH for Unix can export a display for X11. However, neither the client nor the server parts of SecureShell support this functionality. The alternatives, such as IPSec VPNs or Terminal Services have the ability to create a GUI environment for the remote user. You would have to use a console exporter like VNC to get this functionality, although with Windows, you get only one console.

So, to sum things up, SecureShell is a good product for what it is: an SSH daemon running as a Windows service. The product is solid and easy to use, with some good applicability; however, the alternatives to this product could weigh heavily against it.

About the Author

Rick A. Butler, MCSE+I, is the Director of Information Services for the United States Hang Gliding Association.

Featured

comments powered by Disqus

Subscribe on YouTube

Upcoming Training Events

0 AM
TechMentor @ Microsoft HQ
August 11-15, 2025