1999-11-10 10:52:17 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
2019-08-22 07:04:41 +08:00
|
|
|
openssl-genrsa - generate an RSA private key
|
1999-11-10 10:52:17 +08:00
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
B<openssl> B<genrsa>
|
2016-02-06 00:58:45 +08:00
|
|
|
[B<-help>]
|
2019-09-26 03:20:11 +08:00
|
|
|
[B<-out> I<filename>]
|
|
|
|
[B<-passout> I<arg>]
|
2014-07-03 10:42:40 +08:00
|
|
|
[B<-aes128>]
|
|
|
|
[B<-aes192>]
|
|
|
|
[B<-aes256>]
|
2017-02-01 08:10:13 +08:00
|
|
|
[B<-aria128>]
|
|
|
|
[B<-aria192>]
|
|
|
|
[B<-aria256>]
|
2014-07-03 10:42:40 +08:00
|
|
|
[B<-camellia128>]
|
|
|
|
[B<-camellia192>]
|
|
|
|
[B<-camellia256>]
|
1999-11-10 10:52:17 +08:00
|
|
|
[B<-des>]
|
|
|
|
[B<-des3>]
|
|
|
|
[B<-idea>]
|
|
|
|
[B<-f4>]
|
|
|
|
[B<-3>]
|
2019-09-26 03:20:11 +08:00
|
|
|
[B<-rand> I<file...>]
|
|
|
|
[B<-writerand> I<file>]
|
|
|
|
[B<-engine> I<id>]
|
|
|
|
[B<-primes> I<num>]
|
2018-08-09 01:51:23 +08:00
|
|
|
[B<-verbose>]
|
1999-11-10 10:52:17 +08:00
|
|
|
[B<numbits>]
|
|
|
|
|
2019-09-23 07:49:25 +08:00
|
|
|
=for comment ifdef engine
|
|
|
|
|
1999-11-10 10:52:17 +08:00
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
The B<genrsa> command generates an RSA private key.
|
|
|
|
|
|
|
|
=head1 OPTIONS
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
2016-02-06 00:58:45 +08:00
|
|
|
=item B<-help>
|
|
|
|
|
|
|
|
Print out a usage message.
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-out> I<filename>
|
2000-02-08 09:34:59 +08:00
|
|
|
|
2016-02-06 00:58:45 +08:00
|
|
|
Output the key to the specified file. If this argument is not specified then
|
|
|
|
standard output is used.
|
2000-02-08 09:34:59 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-passout> I<arg>
|
2000-02-08 09:34:59 +08:00
|
|
|
|
2017-03-30 05:38:30 +08:00
|
|
|
The output file password source. For more information about the format
|
2019-09-26 03:20:11 +08:00
|
|
|
see L<openssl(1)/Pass phrase options>.
|
2000-02-08 09:34:59 +08:00
|
|
|
|
2018-07-04 00:45:14 +08:00
|
|
|
=item B<-aes128>, B<-aes192>, B<-aes256>, B<-aria128>, B<-aria192>, B<-aria256>, B<-camellia128>, B<-camellia192>, B<-camellia256>, B<-des>, B<-des3>, B<-idea>
|
1999-11-10 10:52:17 +08:00
|
|
|
|
2014-07-03 10:42:40 +08:00
|
|
|
These options encrypt the private key with specified
|
|
|
|
cipher before outputting it. If none of these options is
|
2000-02-08 09:34:59 +08:00
|
|
|
specified no encryption is used. If encryption is used a pass phrase is prompted
|
2000-02-17 07:16:01 +08:00
|
|
|
for if it is not supplied via the B<-passout> argument.
|
1999-11-10 10:52:17 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-F4>|B<-3>
|
1999-11-10 10:52:17 +08:00
|
|
|
|
2017-03-30 05:38:30 +08:00
|
|
|
The public exponent to use, either 65537 or 3. The default is 65537.
|
1999-11-10 10:52:17 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-rand> I<file...>
|
1999-11-10 10:52:17 +08:00
|
|
|
|
2017-03-30 05:38:30 +08:00
|
|
|
A file or files containing random data used to seed the random number
|
2017-07-05 22:58:48 +08:00
|
|
|
generator.
|
2016-03-20 00:28:58 +08:00
|
|
|
Multiple files can be specified separated by an OS-dependent character.
|
2000-04-13 00:48:20 +08:00
|
|
|
The separator is B<;> for MS-Windows, B<,> for OpenVMS, and B<:> for
|
2000-02-25 01:18:51 +08:00
|
|
|
all others.
|
2003-01-31 06:02:27 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-writerand> I<file>
|
2017-07-05 22:58:48 +08:00
|
|
|
|
|
|
|
Writes random data to the specified I<file> upon exit.
|
|
|
|
This can be used with a subsequent B<-rand> flag.
|
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-engine> I<id>
|
2003-01-31 06:02:27 +08:00
|
|
|
|
2017-03-30 05:38:30 +08:00
|
|
|
Specifying an engine (by its unique B<id> string) will cause B<genrsa>
|
2003-01-31 06:02:27 +08:00
|
|
|
to attempt to obtain a functional reference to the specified engine,
|
|
|
|
thus initialising it if needed. The engine will then be set as the default
|
|
|
|
for all available algorithms.
|
1999-11-10 10:52:17 +08:00
|
|
|
|
2019-09-26 03:20:11 +08:00
|
|
|
=item B<-primes> I<num>
|
2017-08-02 02:19:43 +08:00
|
|
|
|
|
|
|
Specify the number of primes to use while generating the RSA key. The B<num>
|
|
|
|
parameter must be a positive integer that is greater than 1 and less than 16.
|
|
|
|
If B<num> is greater than 2, then the generated key is called a 'multi-prime'
|
|
|
|
RSA key, which is defined in RFC 8017.
|
|
|
|
|
2018-08-09 01:51:23 +08:00
|
|
|
=item B<-verbose>
|
|
|
|
|
|
|
|
Print extra details about the operations being performed.
|
|
|
|
|
1999-11-10 10:52:17 +08:00
|
|
|
=item B<numbits>
|
|
|
|
|
2017-03-30 05:38:30 +08:00
|
|
|
The size of the private key to generate in bits. This must be the last option
|
2017-10-18 19:30:23 +08:00
|
|
|
specified. The default is 2048 and values less than 512 are not allowed.
|
1999-11-10 10:52:17 +08:00
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
=head1 NOTES
|
|
|
|
|
2017-08-02 02:19:43 +08:00
|
|
|
RSA private key generation essentially involves the generation of two or more
|
|
|
|
prime numbers. When generating a private key various symbols will be output to
|
2000-02-17 07:16:01 +08:00
|
|
|
indicate the progress of the generation. A B<.> represents each number which
|
|
|
|
has passed an initial sieve test, B<+> means a number has passed a single
|
2017-08-02 02:19:43 +08:00
|
|
|
round of the Miller-Rabin primality test, B<*> means the current prime starts
|
|
|
|
a regenerating progress due to some failed tests. A newline means that the number
|
|
|
|
has passed all the prime tests (the actual number depends on the key size).
|
1999-11-10 10:52:17 +08:00
|
|
|
|
|
|
|
Because key generation is a random process the time taken to generate a key
|
2017-08-02 02:19:43 +08:00
|
|
|
may vary somewhat. But in general, more primes lead to less generation time
|
|
|
|
of a key.
|
1999-11-10 10:52:17 +08:00
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2019-08-22 07:04:41 +08:00
|
|
|
L<openssl(1)>,
|
|
|
|
L<openssl-gendsa(1)>
|
2000-03-19 06:00:26 +08:00
|
|
|
|
2016-05-18 23:44:05 +08:00
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2019-08-22 07:04:41 +08:00
|
|
|
Copyright 2000-2019 The OpenSSL Project Authors. All Rights Reserved.
|
2016-05-18 23:44:05 +08:00
|
|
|
|
2018-12-06 21:04:11 +08:00
|
|
|
Licensed under the Apache License 2.0 (the "License"). You may not use
|
2016-05-18 23:44:05 +08:00
|
|
|
this file except in compliance with the License. You can obtain a copy
|
|
|
|
in the file LICENSE in the source distribution or at
|
|
|
|
L<https://www.openssl.org/source/license.html>.
|
|
|
|
|
|
|
|
=cut
|