Why Verify Digital Signatures
It might happen that a VeraCrypt installation package you download from our server was created or modified by an attacker. For example, the attacker could exploit a vulnerability in the server software we use and alter the installation packages stored on
the server, or he/she could alter any of the files en route to you.
Therefore, you should always verify the integrity and authenticity of each VeraCrypt distribution package you download or otherwise obtain from any source. In other words, you should always make sure that the file was created by us and it was not altered by an attacker. One way to do so is to verify so-called digital signature(s) of the file.
Types of Digital Signatures We Use
We currently use two types of digital signatures:
- PGP signatures (available for all binary and source code packages for all supported systems).
- X.509 signatures (available for binary packages for Windows).
Advantages of X.509 Signatures
X.509 signatures have the following advantages, in comparison to PGP signatures:
- It is much easier to verify that the key that signed the file is really ours (not attacker’s).
- You do not have to download or install any extra software to verify an X.509 signature (see below).
- You do not have to download and import our public key (it is embedded in the signed file).
- You do not have to download any separate signature file (the signature is embedded in the signed file).
Advantages of PGP Signatures
PGP signatures have the following advantages, in comparison to X.509 signatures:
- They do not depend on any certificate authority (which might be e.g. infiltrated or controlled by an adversary, or be untrustworthy for other reasons).
How to Verify X.509 Signatures
Please note that X.509 signatures are currently available only for the VeraCrypt self-extracting installation packages for Windows. An X.509 digital signature is embedded in each of those files along with the digital certificate of the VeraCrypt Foundation issued by a public certification authority. To verify the integrity and authenticity of a self-extracting installation package for Windows, follow these steps:
- Download the VeraCrypt self-extracting installation package.
- In the Windows Explorer, click the downloaded file (‘VeraCrypt Setup.exe’) with the right mouse button and select ‘Properties’ from the context menu.
- In the Properties dialog window, select the ‘Digital Signatures’ tab.
- On the ‘Digital Signatures’ tab, in the ‘Signature list’, double click the line saying "IDRIX" or "IDRIX SARL".
- The ‘Digital Signature Details’ dialog window should appear now. If you see the following sentence at the top of the dialog window, then the integrity and authenticity of the package have been successfully verified:
"This digital signature is OK."
If you do not see the above sentence, the file is very likely corrupted. Note: On some obsolete versions of Windows, some of the necessary certificates are missing, which causes the signature verification to fail.
How to Verify PGP Signatures
To verify a PGP signature, follow these steps:
- Install any public-key encryption software that supports PGP signatures. For Windows, you can download Gpg4win. For more information, you can visit https://www.gnupg.org/.
- Create a private key (for information on how to do so, please see the documentation for the public-key encryption software).
- Download our PGP public key from IDRIX website (https://www.idrix.fr/VeraCrypt/VeraCrypt_PGP_public_key.asc) or from a trusted public key repository (ID=0x54DDD393), and import the downloaded key to your keyring (for information on how to do so, please see the documentation for the public-key encryption software). Please check that its fingerprint is 993B7D7E8E413809828F0F29EB559C7C54DDD393.
- Sign the imported key with your private key to mark it as trusted (for information on how to do so, please see the documentation for the public-key encryption software).
Note: If you skip this step and attempt to verify any of our PGP signatures, you will receive an error message stating that the signing key is invalid.
- Download the digital signature by downloading the PGP Signature of the file you want to verify (on the Downloads page).
- Verify the downloaded signature (for information on how to do so, please see the documentation for the public-key encryption software).
Under Linux, these steps can be achieved using the following commands:
- Check that the fingerprint of the public key is 993B7D7E8E413809828F0F29EB559C7C54DDD393: gpg --with-fingerprint VeraCrypt_PGP_public_key.asc
- If the fingerprint is the expected one, import the public key: gpg --import VeraCrypt_PGP_public_key.asc
- Verify the signature of the Linux setup archive (here for version 1.0e): gpg --verify veracrypt-1.0e-setup.tar.bz2.sig veracrypt-1.0e-setup.tar.bz2