An open API service indexing awesome lists of open source software.

https://github.com/jorabin/KeePassJava2

Java API for KeePass Password Databases - Read/Write 2.x (File versions 3 and 4), Read 1.x
https://github.com/jorabin/KeePassJava2

kdb kdbx keepass

Last synced: 4 days ago
JSON representation

Java API for KeePass Password Databases - Read/Write 2.x (File versions 3 and 4), Read 1.x

Awesome Lists containing this project

README

        

# KeePassJava2

[![Maven Central](https://maven-badges.herokuapp.com/maven-central/org.linguafranca.pwdb/KeePassJava2-parent/badge.svg)](https://maven-badges.herokuapp.com/maven-central/org.linguafranca.pwdb/KeePassJava2-parent)
[![javadoc](https://javadoc.io/badge2/org.linguafranca.pwdb/KeePassJava2/javadoc.svg)](https://javadoc.io/doc/org.linguafranca.pwdb/KeePassJava2)

![alt text](https://badgen.net/badge/Build/2.2.4/blue?icon=github)
master [![CircleCI](https://dl.circleci.com/status-badge/img/gh/jorabin/KeePassJava2/tree/master.svg?style=shield)](https://dl.circleci.com/status-badge/redirect/gh/jorabin/KeePassJava2/tree/master)
develop [![CircleCI](https://dl.circleci.com/status-badge/img/gh/jorabin/KeePassJava2/tree/develop.svg?style=shield)](https://dl.circleci.com/status-badge/redirect/gh/jorabin/KeePassJava2/tree/develop)

A Java 8 API for databases compatible with the renowned [KeePass](http://keepass.info) password
safe for Windows. This is a "headless" implementation - if you want something with a UI
then [KeePassXC](https://keepassxc.org/) and [KeePassDX](https://www.keepassdx.com/) could
be just the things for you.

Features to date:

- Read and write KeePass 2.x format (KDBX file formats V3 and V4)
- Keepass 2.x Password and Keyfile Credentials
- Read KeePass 1.x format (Rijndael only)
- *No* requirement for JCE Policy Files
- Android compatible
- Interfaces for Database, Group and Entry allow compatible addition of other formats

It is licensed under the Apache 2 License and is currently usable.

The work is provided on an "AS IS" BASIS, WITHOUT
WARRANTIES OR CONDITIONS OF ANY KIND, either express or
implied, including, without limitation, any warranties
or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY,
or FITNESS FOR A PARTICULAR PURPOSE.

You are solely responsible for determining the appropriateness
of using or redistributing the Work and assume any risks
associated with Your exercise of permissions under this License.

(see [license](#license))

## Current Status

The current code is version 2.2.4 - released to Maven March 2025. This is on the main branch. See [Build from Source](#build-from-source)

Key updates relative to 2.1:
- Java 8 (dependencies no longer support Java 7)
- File format version 4 support - with Argon2
- Inclusion of Jackson based KDBX support with a view to removing SimpleXML, JAXB and JAXB support
- Updated keyfile support
- Updated dependencies

See the [changelog](CHANGELOG.md) for more details.

## Maven Coordinates

### Release

The POM for the last release (2.2.4), Java 8 compatible, is

org.linguafranca.pwdb
KeePassJava2-jackson
2.2.4

at Maven Central. This provides access to the Jackson based implementation,
which is now the recommended implementation. There is also a composite POM that
provides access to all implementations (see [below](#database-implementations) for discussion).

org.linguafranca.pwdb
KeePassJava2
2.2.4

Note that the artifactId has become Camel Case from release 2.1.x onwards.

### Snapshot

Snapshot builds are erratically available at [Sonatype](https://oss.sonatype.org/content/repositories/snapshots/org/linguafranca/pwdb/), next bug-fix release will be
2.2.5-SNAPSHOT (on branch `develop`) and work-in-progress 3.0.0-SNAPSHOT (on branch `v3`):

org.linguafranca.pwdb
KeePassJava2
2.2.5-SNAPSHOT

with appropriate `` entry, like:



oss.sonatype.org-snapshot
https://oss.sonatype.org/content/repositories/snapshots

false


true




There are also separate POMs for the various modules. The module structure is illustrated below
under [Build from Source](#build-from-source).

## Java Version

From release 2.2 it requires Java 1.8. From release 3, Java 11. Earlier versions require Java 1.7.

## Quick Start

Create credentials and an input stream for the password vault in question:

KdbxCreds creds = new KdbxCreds("123".getBytes());
InputStream inputStream = getClass().getClassLoader().getResourceAsStream("test1.kdbx");

then choose the Jackson based database implementation, and load the database

Database database = JacksonDatabase.load(creds, inputStream)

See [below](#database-implementations) for discussion of other database implementations. Note that they will not be
maintained in the future - and see the following regarding making the storage of
passwords more secure.

### Storing Passwords

There are numerous well-understood problems
with storing passwords as Strings in Java. See [this discussion](./PropertyValueProtection.md) about the
KeePassJava2 approach to storing passwords.

> Available from release 2.2.3 the enhanced **Jackson implementation** is the only KeePassJava2 database implementation that provides a
means of storing passwords other than as String.

### Discussion

Password databases are modelled as a three layer abstraction.

A *Database* is a collection of records whose physical representation needs only to be capable of rendering as a stream. *Entries* hold the information of value in the database and *Groups* allow the structuring of entries into collections, just like a folder structure.

The Database has a root group and by following subgroups of the root group the tree structure of the database can be navigated. Entries belong to groups. Entries can be moved between groups and groups can also be moved between groups. However, entries and groups created in one database cannot be moved to another database without being converted:

database.newEntry(entryToCopy);
database.newGroup(groupToCopy);

The class Javadoc on Interface classes
[Database](http://javadoc.io/page/org.linguafranca.pwdb/database/latest/org/linguafranca/pwdb/Database.html),
[Group](http://javadoc.io/page/org.linguafranca.pwdb/database/latest/org/linguafranca/pwdb/Group.html) and
[Entry](http://javadoc.io/page/org.linguafranca.pwdb/database/latest/org/linguafranca/pwdb/Entry.html) describe
how to use the methods of those classes to create and modify entries. These classes
provide the basis of all implementations of the various database formats,
initially KDB, KDBX 3.1 and KDBX 4 (KeePass 2) file formats, subsequently, potentially, others.

The class [QuickStart.java](example/src/main/java/org/linguafranca/pwdb/kdbx/QuickStart.java) provides some
illustrations of operations using the Database, Group and Entry interfaces.

### KeePassJava2 and KeePass

This project is so named by kind permission of Dominik Reichl the author of KeePass. There
is no formal connection with that project.

It has always been the intention to support other specific password database implementations.
Hence, the creation of abstract Database interfaces rather than following the KeePass model
exactly.

KeePass is in effect defined by the code that Dominik writes to create and maintain the project and
[KDBX File Format Specification](https://keepass.info/help/kb/kdbx.html) describes the file format. There
is also a discussion of the [differences between KDBX version 3.1 and version 4](https://keepass.info/help/kb/kdbx_4.html).
Additionally, there is a discussion of the [enhancements in KDBX 4.1](https://keepass.info/help/kb/kdbx_4.1.html), as well
as a discussion of [Key Files](https://keepass.info/help/base/keys.html#keyfiles).

Massive credit also to the folks over at [KeePassXC](https://keepassxc.org/) who wrote some
[documentation](https://github.com/keepassxreboot/keepassxc-specs) about their understanding of various format things. Also, this is a
useful [discussion/investigation](https://github.com/scubajorgen/KeepassDecrypt) of the KDBX format.

For the sake of
clarification and my own satisfaction I have written about my understanding of
KeePass formats in the following locations:

1. The Javadoc header to [KdbxSerializer](http://javadoc.io/page/org.linguafranca.pwdb/KeePassJava2-kdbx/latest/org/linguafranca/pwdb/kdbx/stream_3_1/KdbxSerializer.html) describes KDBX stream formatting.
2. The XSD Schema [KDBX.4.xsd](KDBX.4.xsd) documents my understanding of the Keepass XML, and also my
lack of understanding, in parts. While preparing release 2.2.3 I found [this XSD](https://keepass.info/help/download/KDBX_XML.xsd) at the
KeePass site. I have not (so far) attempted to reconcile my documentation with it.
3. The following graphic illustrates KDBX 3.1 and 4 file formats:

[![KDBX Formats](KdbxDiagram.svg "KDBX Formats")](KdbxDiagram.svg)

## Database Implementations

KeePass - or more specifically its file format KDBX - is an XML based format, so one of the main tasks
is serializing and deserializing XML. Over time (KeePassJava2 was originally released in 2014) approaches
to Java and XML have been a bit mysterious. However, Jackson has now been chosen as the
underlying framework for implementation of KeePassJava2.

There are several other database implementations which will be maintained for bug-fix purposes
only, with a view to being withdrawn, since they perform badly and/or depend on obsolete technology.

- `SimpleXML` - no longer maintained, does not work with Java 17 and up
- `JAXB` - this causes problems with `javax` and `jakarta` namespaces, it's not worth maintaining
as it offers no compelling performance or other advantage
- `DOM` the was the original implementation and validates the fact that DOM based implementations
are slow. That said, if you want to load a database and then save it while maintaining whatever quirks
existed in the original database then this is the one.

Aside from dependencies on underlying frameworks, different implementations have varying characteristics, primarily speed. This is assessed
by [this test](https://github.com/jorabin/KeePassJava2/blob/master/example/src/main/java/org/linguafranca/pwdb/kdbx/OpenDbExample.java) in the module `examples`.

## Dependencies

Aside from the JRE, at release 2.2, the API depends on:

- [Google Guava](https://github.com/google/guava/wiki) ([Apache 2 license](https://github.com/google/guava/blob/master/COPYING)).
- [Apache Commons Codec](https://commons.apache.org/proper/commons-codec/) ([Apache 2 license](http://www.apache.org/licenses/LICENSE-2.0)).
- [Bouncy Castle](https://github.com/bcgit/bc-java/blob/master/LICENSE.html) ([MIT License](https://github.com/bcgit/bc-java/blob/master/LICENSE.html)).

The Jackson implementation depends on:

- [Faster XML Jackson](https://github.com/FasterXML/jackson)

The (historical) Simple XML implementation additionally depends on:

- [Simple XML Serialisation Framework](http://simple.sourceforge.net/) ([Apache 2 license](http://www.apache.org/licenses/LICENSE-2.0)).
- [Faster XML Aalto](https://github.com/FasterXML/aalto-xml) ([Apache 2 license](http://www.apache.org/licenses/LICENSE-2.0.txt)).

For Java 11 and later, Jaxb implementation depends on explicit inclusion [no longer provided by JDK](https://docs.oracle.com/en/java/javase/11/migrate/index.html#JSMIG-GUID-F640FA9D-FB66-4D85-AD2B-D931174C09A3) of:

- [JAXB](https://javaee.github.io/jaxb-v2/)

It also depends on SLF4J and Junit 4 for tests.

## Build from Source

Included POM is for Maven 3.

### Module Structure

There are rather a lot of modules, this is in order to allow loading of minimal necessary functionality. The module dependencies are illustrated below.

[![Module Structure](ModuleStructure.svg "Module Structure")](./ModuleStructure.svg)

Each module corresponds to a Maven artifact. The GroupId is `org.linguafranca.pwdb`. The version id is as noted [above](#maven-coordinates).

ModuleArtifactIdJavaDocDescription

databasedatabase

Javadocs

Base definition of the Database APIs.
exampleexample
Javadocs
Worked examples of loading, saving, splicing etc. using the APIs

testtest
Javadocs
Shared tests to assess the viability of the implementation.

allKeePassJava2
(no JavaDoc)
This is the main KeePassJava2 Maven dependency. Provides a route to all artifacts (other than test and examples) via transitive dependency.

kdbKeePassJava2-kdb
Javadocs
An implementation of the Database APIs supporting KeePass KDB format.

kdbxKeePassJava2-kdbx
Javadocs
Provides support for KDBX streaming and security.

jacksonKeePassJava2-jackson
Javadocs
A Jackson based implementation of KDBX. Intended to provide the main support going forward, replacing trhe
modules below.

simpleKeePassJava2-simple
Javadocs
A Simple XML Platform implementation of KDBX. Could be useful for Android.
Simple cannot be used with Java versions 17 and up.

jaxbKeePassJava2-jaxb
Javadocs
A JAXB implementation of KDBX. Probably not useful for Android. The generated class
bindings might be useful for building other interfaces.

domKeePassJava2-dom
Javadocs
A DOM based implementation of KDBX. Being DOM based it is rather slow, but
messes less with existing content than the other implementations. Known to work on Android.

Why are there so many implementations for KDBX? Well, the DOM implementation came first, because it can
load and save stuff that the implementation doesn't specifically know about. But it is very slow.

Then came the JAXB implementation, but
belatedly it seems that Android support is in question. So latterly the Simple implementation. That was probably enough
KDBX implementations, however, the Simple XML library seems no longer to be maintained,
and along comes the Jackson Implementation.

Jackson is the implementation going forward.

### Gradle

If you prefer Gradle the automatic conversion `gradle init` has been known to convert the POM successfully, however you will
need to add something like [gradle-source-sets.txt](jaxb/gradle-source-sets.txt) to the `build.gradle` for the JAXB module, so that the generated sources
get compiled correctly.

## Change Log

In [this file](./CHANGELOG.md).

## Acknowledgements

Many thanks to Pavel Ivanov [@ivanovpv](https://github.com/ivanovpv) for
his help with Android and Gradle compatibility issues back in the very early days.

Thanks to Giuseppe Valente [@giusvale-dev](https://github.com/giusvale-dev) for
his contribution of the Jackson module and enhancements to KeyFile support.

Thanks to other contributors and raisers of issues.

## License

Copyright (c) 2025 Jo Rabin

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.