KeePass
KeePass Password Safe is a free and open-source password manager primarily for Windows. It officially supports macOS and Linux operating systems through the use of Mono.[2] Additionally, there are several unofficial ports for Windows Phone, Android, iOS, and BlackBerry devices.[3][4][5][6][7] KeePass stores usernames, passwords, and other fields, including free-form notes and file attachments, in an encrypted file. This file can be protected by any combination of a master password, a key file, and the current Windows account details. By default, the KeePass database is stored on a local file system (as opposed to cloud storage).[8]
KeePass 2.x Main Window | |
Developer(s) | Dominik Reichl |
---|---|
Initial release | November 16, 2003 |
Stable release | 2.47[1] (January 9, 2021 ) [±] |
Repository | none |
Written in | C# (2.x version), C++ (1.x version) |
Operating system | Windows Vista and later (plus other platforms in unofficial derivatives) |
Platform | .NET Framework, Mono |
Available in | English |
Type | Password manager |
License | GNU GPLv2+ |
Website | keepass |
KeePass supports a number of plugins.[9] It has a password generator and synchronization function, supports two-factor authentication, and has a Secure Desktop mode. It can use a two-channel auto-type obfuscation feature to offer additional protection against keyloggers.[10] KeePass can import from over 30 other most commonly used password managers.[10]
A 2017 Consumer Reports article described KeePass as one of the four most widely used password managers (alongside 1Password, Dashlane and LastPass), being "popular among tech enthusiasts" and offering the same level of security as non-free competitors.[11]
A 2019 Independent Security Evaluators study described KeePass as well as other widely used password managers as being unable to control Windows 10's tendency to leave passwords in cleartext in RAM after they are displayed using Windows controlled GUI.[12] In addition, several github projects (KeeFarce, KeeThief, Lazanga) specifically attack a running KeePass to steal all data; when the host is compromised. KeePass cannot prevent password theft and "neither KeePass nor any other password manager can magically run securely in a spyware-infected, insecure environment."[13]
Overview
Import and export
The password list is saved by default as a .kdbx file, but it can be exported to TXT, HTML, XML and CSV.[14] The XML output can be used in other applications and re-imported into KeePass using a plugin. The CSV output is compatible with many other password safes like the commercial closed-source Password Keeper and the closed-source Password Agent. Also, the CSVs can be imported by spreadsheet applications like Microsoft Excel or OpenOffice/LibreOffice Calc.
File format support can be expanded through the use of KeePass plugins.[15]
Multi-user support
KeePass supports simultaneous access and simultaneous changes to a shared password file by multiple computers (often by using a shared network drive), however there is no provisioning of access per-group or per-entry.[16] As of May 2014, there are no plugins available to add provisioned multi-user support, but there exists a proprietary password server (Pleasant Password Server) that is compatible with the KeePass client and includes provisioning.[17]
Auto-type, global auto-type hotkeys, and drag and drop
KeePass can minimize itself and type the information of the currently selected entry into dialogs, webforms, etc. KeePass has a global auto-type hot key. When KeePass is running in the background (with opened database) and the user presses the hotkey, it looks up the correct entry and executes its auto-type sequence.[18] All fields, such as title, username, password, URL, and notes, can be drag and dropped into other windows.
Windows clipboard handling allows double-clicking on any field of the password list to copy its value to the Windows clipboard. KeePass can clear the clipboard automatically some time after the user has copied one of their passwords into it. KeePass features protection against clipboard monitors (other applications will not get notifications that the clipboard content has been changed).
KeePass at one time had a paste-once functionality, where after a single paste operation, the clipboard would be cleared automatically, but this was removed in version 2.x due to incompatibility and insufficient effectiveness.[19]
Browser support
The auto-type functionality works with all windows, and consequently with all browsers. The KeeForm extension allows users to open websites with Internet Explorer and Mozilla Firefox and fill in user details automatically. Internet Explorer also has a browser integration toolbar available.[20]
For Firefox, an extension called KeeFox connects to KeePass when a user needs to access a password from it.[21]
Built-in password generator
KeePass features a built-in password generator that generates random passwords. Random seeding can be done through user input (mouse movement and random keyboard input).[18]
Plugins
KeePass has a plugin architecture. There are various plugins available from the KeePass website (such as import/export from/to various other formats, database backup, integration, automation, etc.). Note that plugins may compromise the security of KeePass, because they are written by independent authors and have full access to the KeePass database.
Wrapper
KeePass has an opensource wrapper, QuicKeepass, that allows the use of KeePass more efficiently on Linux.[22]
Cryptography
Runtime security
According to the utility's author, KeePass was one of the first password management utilities to use security-enhanced password edit controls, in this case one called CSecureEditEx.[23] The author makes several claims regarding the security of the control and its resistance to password revealing utilities; however, the author does not cite or make any references to any third-party testing of the control to corroborate the claims of its security.[24]
Passwords are protected in memory while KeePass is running. On Windows Vista and later versions, passwords are encrypted in process memory using Windows Data Protection API, which allows storing the key for memory protection in a secure, non-swappable memory area. On previous Windows systems, KeePass falls back to using the ARC4 cipher with a temporary, random session key.[25]
Offline security
Access to the database is restricted by a master password or a key file. Both methods may be combined to create a "composite master key". If both methods are used, then both must be present to access the password database. KeePass version 2.x introduces a third option—dependency upon the current Windows user.[26] KeePass encrypts the database with the AES, Twofish or ChaCha20 symmetric cipher, where the first two are used in CBC/PKCS7 mode. AES is the default option in both KeePass editions, Twofish is available in KeePass 1.x, ChaCha20 is available only in KeePass 2.35 and higher.[27] However, a separate plugin provides Twofish as an encryption algorithm in KeePass 2.x. In KeePass 1.x (KDB database format), the integrity of the data is checked using a SHA-256 hash of the plaintext, whereas in KeePass 2.x (KDBX database format), the authenticity of the data is ensured using a HMAC-SHA-256 hash of the ciphertext (Encrypt-then-MAC construction).[28]
Notable KeePass derivatives
- KeePassX, a multi-platform open source KeePass clone for Linux and macOS, built using the Qt libraries.[29]
- KeePassXC (KeePass Cross-Platform Community Edition) is a fork of KeePassX written in C++.[30]
- KeeWeb, a cross-platform JavaScript web application using the KeePass database format, desktop version built with Electron.
See also
References
- KeePass 2.47 released on KeePass website
- "KeePass Setup". KeePass.info.
- "Download page". KeePass.info.
- "KeePass reader for Windows Phone".
- "KeePassDroid".
- "KeePass for Blackberry".
- "iOS application".
- Zukerman, Erez. "Tools for the Paranoid: 5 Free Security Tools to Protect Your Data". PC World. Retrieved 2013-07-14.
- "KeePass Plugins".
- Rubenking, Neil. "KeePass Review & Ratings". PC Magazine. Retrieved 2014-06-11.
- Chaikivsky, Andrew (2017-02-17). "Everything You Need to Know About Password Managers". Consumer Reports. Retrieved 2018-06-23.
- Bednarek, Adrian. "Password Managers: Under the Hood of Secrets Management". Retrieved 2019-03-24.
- Reichl, Dominik. "KeeFarce". Retrieved 2019-03-24.
- Reichl, Dominik (2019). "KeePass Features". KeePass.info. Retrieved 2019-12-31.
- "KeePass 2.x Plugins". KeePass.info. Retrieved 2019-01-26.
- Reichl, Dominik. "KeePass Help Center". Retrieved 2012-12-28.
- "Pleasant Password Server". Retrieved 2014-05-29.
- Markton, Ben. "KeePass Password Safe Professional". CNET.com. Retrieved 2014-06-11.
- Reichl, Dominik. "What happened to the paste-once functionality in 2.x? – KeePass Forums". Retrieved 2012-10-14.
- KeeForm (undated). Retrieved on 2014-06-24 from http://www.keeform.org.
- "Home". KeeFox. Retrieved 2014-06-24.
- "QuicKeepass".
- Reichl, Dominik. "Secure Edit Controls – KeePass". Retrieved 2009-11-14.
- Reichl, Dominik (2005-04-17). "CSecureEditEx – A More Secure Edit Control". The Code Project. Archived from the original on 2006-02-17.
- Reichl, Dominik. "Security – KeePass". Retrieved 2007-12-13.
- Reichl, Dominik. "Composite Master Key – KeePass". Retrieved 2009-11-14.
- Reichl, Dominik. "News: KeePass 2.35 available!". keepass.info. Retrieved 2020-10-11.
- Reichl, Dominik. "Security - KeePass". Retrieved 2020-10-11.
- "KeePassX 2.0 has arrived". Geyer, Felix. Retrieved 2015-12-07.
- "KeePassXC Password Manager". keepassxc.org. Retrieved 26 January 2017.