EnglishFrenchSpanish

OnWorks favicon

mcrypt - Online in the Cloud

Run mcrypt in OnWorks free hosting provider over Ubuntu Online, Fedora Online, Windows online emulator or MAC OS online emulator

This is the command mcrypt that can be run in the OnWorks free hosting provider using one of our multiple free online workstations such as Ubuntu Online, Fedora Online, Windows online emulator or MAC OS online emulator

PROGRAM:

NAME


crypt, mcrypt, mdecrypt - encrypt or decrypt files

SYNOPSIS


mcrypt [ -dLFubhvrzp ] [-a algorithm] [-c config_file] [-m mode] [-s keysize] [-o keymode]
[-k key1 key2 ...] [-f keyfile] [ filename ... ]

mdecrypt [ -LFusbhvzp ] [-a algorithm] [-c config_file] [-m mode] [-s keysize]
[-o keymode] [-k key1 key2 ...] [-f keyfile] [ filename ... ]

DESCRIPTION


Mcrypt is a simple crypting program, a replacement for the old unix crypt(1). When
encrypting or decrypting a file, a new file is created with the extension .nc and mode
0600. The new file keeps the modification date of the original. The original file may be
deleted by specifying the -u parameter. If no files are specified, the standard input is
encrypted to the standard output.

Mcrypt uses all the symmetric algorithms included in libmcrypt.

crypt is a small shell wrapper around mcrypt to emulate the old unix crypt command. For
more information run crypt --help !

HINTS


By default, mcrypt , when one of these algorithms is specified, prompts something like:
Enter passphrase: ...
You should then enter a passphrase long enough (512 characters is the maximum length).
Now in order to encrypt the file, The passphrase is transformed using the specified (or
the default) key generation algorithm, and a random salt. The produced value is then used
as the key, which is fed to the algorithm.

Algorithm Vulnerability: Most algorithms today are designed to resist in specific attacks.
None of them is proved not to be vulnerable to some kind of attack not as yet known.

Compression: By compressing your data before encryption you gain both in efficiency
(faster encryption) and safety of your data (language redundancy is removed). A drawback
is that most compression programs will add specific headers in the compressed file, thus
making known plaintext attacks easier. Compression after encryption is useless and may
result to compressed files with longer size than the original.

Error Recovery: There is some error recovery in mcrypt. If bytes are removed or lost from
the file or stream in ECB, CBC and OFB modes, are impossible to recover, although CFB mode
will recover. If some bytes are altered then a full block of plaintext is affected in ECB
mode, two blocks in CBC and CFB modes, but only the corresponding byte in OFB mode.
Mcrypt uses a 32 bit CRC to check for errors in the encrypted files.

Extra security: For the very paranoid, if mcrypt is executed with superuser priviledges it
ensures that no important data (keys etc.) are written to disk, as swap etc. Keep in mind
that mcrypt was not designed to be a setuid program, so you shouldn't make it one.

Do not rely on the fact that an algorithm has a large key size, try to use long
passphrases and try to make them unpredictable.

All the block algorithms above support these modes of encryption:

ECB: The Electronic CodeBook mode. It is the simplest mode to use with a block cipher.
Encrypts each block independently.

CBC: The Cipher Block Chaining mode. It is better than ECB since the plaintext is XOR'ed
with the previous ciphertext. A random block is placed as the first block so the same
block or messages always encrypt to something different. (This is the default mode)

CFB: The Cipher-Feedback Mode (in 8bit). This is a self-synchronizing stream cipher
implemented from a block cipher.

OFB: The Output-Feedback Mode (in 8bit). This is a synchronous stream cipher implemented
from a block cipher. It is intended for use in noisy lines, because corrupted ciphertext
blocks do not corrupt the plaintext blocks that follow. Insecure when used to encrypt
large amounts of data, so I recommend against using it.

nOFB: The Output-Feedback Mode (in nbit). n Is the size of the block of the algorithm.
This is a synchronous stream cipher implemented from a block cipher. It is intended for
use in noisy lines, because corrupted ciphertext blocks do not corrupt the plaintext
blocks that follow.

Encrypted files can be restored to their original form using mcrypt -d or mdecrypt

mdecrypt takes a list of files on its command line and creates a new file for each file
whose name ends with .nc by removing the ".nc" or by adding ".dc" to the end of the file
name if .nc is not in the encrypted file's name.

OPTIONS


-F --force
Force output on standard output or input from stdin if that is a terminal. By
default mcrypt will not output encrypted data to terminal, nor read encrypted data
from it.

-z --gzip
Use gzip (if it exists in your system) to compress files before encryption. If
specified at decryption time it will decompress these files.

-p --bzip2
Use bzip2 (if it exists in your system) to compress files before encryption. If
specified at decryption time it will decompress these files.

--openpgp-z INT
This option will enable compression in OpenPGP (RFC2440) encrypted files.

-d --decrypt
Decrypt.

--help
Display a help screen and quit.

-v --version
Version. Display the version number and quit.

-L --license
Display the mcrypt's license and quit.

-o --keymode MODE
MODE may be one of the keymodes listed by the --list-keymodes parameter. It
actually is the convertion to the key before it is fed to the algorithm. It is
recommended to leave it as is, if you do not know what it is. However if you still
want to use this option, you might want to use the 'hex' mode which allows you to
specify the key in hex (and no convertion will by applied).

-h --hash HASH_ALGORITHM
HASH_ALGORITHM may be one of the algorithms listed by the --list-hash parameter.
This is the digest that will be appended to the file to be encrypted, in order to
detect file corruption. The default is the CRC32 checksum.

-s --keysize SIZE
SIZE is the algorithm's key size in bytes (not the size of the passphrase). It
defaults to the maximum key supported by the algorithm. The maximum key sizes of
the algorithms may be obtained by the --list parameter. It is safe not to touch
this.

-g --openpgp
This option will make mcrypt to use the OpenPGP (RFC2440) file format for encrypted
files. This will make files encrypted by mcrypt accessible from any OpenPGP
compliant application.

-b --bare
No important information like the algorithm, mode, the bit mode and the crc32 of
the original file are written in the encrypted file. The security lies on the
algorithm not on obscurity so this is NOT the default. This flag must also be
specified when decrypting a bare encrypted file. When the bare flag is specified
decryption and encryption are faster. This may be usefull when using mcrypt to
encrypt a link or something like that.

--flush
Flushes the output (ciphertext or plaintext) immediately. Usefull if mcrypt is used
with pipes.

--time Prints some timing information (encryption speed etc.)

--nodelete
When this option is specified mcrypt does not delete the output file, even if
decryption failed. This is usefull if you want to decrypt a corrupted file.

-q --quiet
Suppress some not critical warnings.

-u --unlink
Unlink (delete) the input file if the whole process of encryption/decryption
succeeds. This is not the default in order to use an external program to remove
sensitive data.

--list
Lists all the algorithms currently supported.

--list-keymodes
Lists all the key modes currently supported.

--list-hash
Lists all the hash algorithms currently supported.

-r --random
Use /dev/(s)random instead of /dev/urandom. This may need some key input or mouse
move to proceed. If your system does not support /dev/random or /dev/urandom, a
random gatherer will be used.

-k --key KEY1 KEY2 ...
Enter the keyword(s) via the command line. The KEY(s) is/are then used as keyword
instead of prompting for them. Keep in mind that someone may see the command you
are executing and so your keyword(s).

-c --config FILE
Use the specified configuration file. The default is .mcryptrc in your home
directory. The format of the configuration file is the same as the parameters. An
example file is:
algorithm safer+
mode cbc
key a_very_secret_one

-f --keyfile FILE
Enter the keyword(s) via a file. One keyword is read per line. The first keyword
read is used for the first file, the second for the second file etc. If the
keywords are less than the files then the last keyword is used for the remaining. A
limitation is that you cannot use the NULL (\0) and the Newline (\n) character in
the key. A solution to this problem is to specify the keyword in hex mode.

-m --mode MODE
Mode of encryption and decryption. These modes are currently supported: ECB, CFB,
OFB, nOFB, CBC and STREAM. CBC is the default. Unless the bare flag is specified
there is no need to specify these modes for decryption. For stream algorithms
(like WAKE) mode should be STREAM.

-a --algorithm ALGORITHM
The algorithm used to encrypt and decrypt. Unless the bare flag is specified there
is no need to specify these for decryption.

The algorithms currently supported are shown with the --list parameter.

EXAMPLES


For mcrypt to be compatible with the solaris des(1), the following parameters are needed:
"mcrypt -a des --keymode pkdes --bare --noiv filename".

For mcrypt to be compatible with the unix crypt(1), the following parameters are needed:
"mcrypt -a enigma --keymode scrypt --bare filename".

To encrypt a file using a stream algorithm (eg. Arcfour), the following parameters are
needed: "mcrypt -a arcfour --mode stream filename".

ENVIRONMENT


Mcrypt uses the following environment variables:

MCRYPT_KEY: to specify the key

MCRYPT_ALGO: to specify the algorithm

MCRYPT_MODE: to specify the algorithm's mode

MCRYPT_KEY_MODE: to specify the key mode

You can use these instead of using the command line (which is insecure), but note that
only one key should be used in MCRYPT_KEY.

Use mcrypt online using onworks.net services


Free Servers & Workstations

Download Windows & Linux apps

  • 1
    Osu!
    Osu!
    Osu! is a simple rhythm game with a well
    thought out learning curve for players
    of all skill levels. One of the great
    aspects of Osu! is that it is
    community-dr...
    Download Osu!
  • 2
    LIBPNG: PNG reference library
    LIBPNG: PNG reference library
    Reference library for supporting the
    Portable Network Graphics (PNG) format.
    Audience: Developers. Programming
    Language: C. This is an application that
    can also...
    Download LIBPNG: PNG reference library
  • 3
    Metal detector based on  RP2040
    Metal detector based on RP2040
    Based on Raspberry Pi Pico board, this
    metal detector is included in pulse
    induction metal detectors category, with
    well known advantages and disadvantages.
    RP...
    Download Metal detector based on RP2040
  • 4
    PAC Manager
    PAC Manager
    PAC is a Perl/GTK replacement for
    SecureCRT/Putty/etc (linux
    ssh/telnet/... gui)... It provides a GUI
    to configure connections: users,
    passwords, EXPECT regula...
    Download PAC Manager
  • 5
    GeoServer
    GeoServer
    GeoServer is an open-source software
    server written in Java that allows users
    to share and edit geospatial data.
    Designed for interoperability, it
    publishes da...
    Download GeoServer
  • 6
    Firefly III
    Firefly III
    A free and open-source personal finance
    manager. Firefly III features a
    double-entry bookkeeping system. You can
    quickly enter and organize your
    transactions i...
    Download Firefly III
  • More »

Linux commands

Ad