Locking the Keyboard and Mouse at Scheduled Times

Environment: Windows 9x

Introduction

This program locks keyboard and mouse on computers running Windows 9x.

My boss needed something that would prevent users from using the computer at a specified time (e.g., 7 PM). But the user was to be able to use it again next morning (e.g., at 9 AM). The software was intended for use only on Windows 9x systems. After searching for something similar, I decided to write my own.

The result is presented here. At a specified time, it turns off all special keys (Ctrl-Alt-Del, Alt-Tab, Ctrl-Esc, Windows key), then intercepts all keyboard input, as well as WM_LBUTTONDOWN event, so that the user won't be able to do anything on the computer. Rebooting doesn't help either, because this program automatically runs at startup (I know, it might look like a Trojan horse, but that was my requirement :))

To intercept keyboard and mouse input I install a system-wide hook. A hook is a point in the system message-handling mechanism where an application can install a subroutine to monitor the message traffic in the system and process certain types of messages before they reach the target window procedure. To install a hook use SetWindowsHookEx() function. It takes 4 parameters:
    int idHook: Specifies the type of hook procedure to be installed. In this case it is WH_KEYBOARD for keyboard hook and WH_MOUSE for mouse hook.

    HOOKPROC lpfn: Pointer to the hook procedure. Since I want to install a system-wide hook, it must point to a hook procedure in a dynamic-link library (DLL).

    HINSTANCE hMod: Handle to the DLL containing the hook procedure pointed to by the lpfn parameter.

    DWORD dwThreadId: Specifies the identifier of the thread with which the hook procedure is to be associated. If this parameter is zero, the hook procedure is associated with all existing threads running in the same desktop as the calling thread.

To disable special keys (Ctrl-Alt-Del, Alt-Tab, Ctrl-Esc, Windows key) I used SystemParametersInfo() function with SPI_SETSCREENSAVERRUNNING flag. Even though applications are not supposed to use this flag, because it is used internally in Windows 9x, it does the job.

On startup, the program checks if there is another instance of the same program running. If so, it terminates. Otherwise, it checks where it is run from, and tries to install itself in System folder and RunServices key of Windows registry. Afterwards, it renames itself to "mskml32.exe" and tries to delete the original file. Default start time is set to 7 PM, and default end time is 9 AM. These times are specified in "HKLM\Software\Windows\CurrentVersion\Explorer\Services" key. At a specified start time it disables special key combinations, and installs keyboard and mouse hooks. At any time you can type "unl0ck" to remove hooks and enable special key combinations. By the way, in this version password is hard-coded into the program. You are welcome to modify the source code, so that it checks a password from some other location.

Feel free to adapt this program to your special needs. It's a great way to learn how hooks work.

Downloads

Download demo project - 47 Kb


Comments

  • CTRL+ALT+DEL

    Posted by DEX348 on 07/31/2005 01:31pm

    KeyboardControl SDK allows that on all Windows version

    Reply
  • Comments

    Posted by x3r0 on 04/11/2005 01:48am

    I'm surprised you would write any program without any useful comments.

    Reply
Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • U.S. companies are desperately trying to recruit and hire skilled software engineers and developers, but there is simply not enough quality talent to go around. Tiempo Development is a nearshore software development company. Our headquarters are in AZ, but we are a pioneer and leader in outsourcing to Mexico, based on our three software development centers there. We have a proven process and we are experts at providing our customers with powerful solutions. We transform ideas into reality.

  • When individual departments procure cloud service for their own use, they usually don't consider the hazardous organization-wide implications. Read this paper to learn best practices for setting up an internal, IT-based cloud brokerage function that service the entire organization. Find out how this approach enables you to retain top-down visibility and control of network security and manage the impact of cloud traffic on your WAN.

Most Popular Programming Stories

More for Developers

RSS Feeds

Thanks for your registration, follow us on our social networks to keep up-to-date