1999-11-10 03:52:17 +01:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
genrsa - generate an RSA private key
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
B<openssl> B<genrsa>
|
|
|
|
[B<-out filename>]
|
2000-02-17 00:16:01 +01:00
|
|
|
[B<-passout arg>]
|
1999-11-10 03:52:17 +01:00
|
|
|
[B<-des>]
|
|
|
|
[B<-des3>]
|
|
|
|
[B<-idea>]
|
|
|
|
[B<-f4>]
|
|
|
|
[B<-3>]
|
2000-01-16 00:19:22 +01:00
|
|
|
[B<-rand file(s)>]
|
2003-01-30 23:02:27 +01:00
|
|
|
[B<-engine id>]
|
1999-11-10 03:52:17 +01:00
|
|
|
[B<numbits>]
|
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
The B<genrsa> command generates an RSA private key.
|
|
|
|
|
|
|
|
=head1 OPTIONS
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
2000-02-08 02:34:59 +01:00
|
|
|
=item B<-out filename>
|
|
|
|
|
|
|
|
the output filename. If this argument is not specified then standard output is
|
|
|
|
used.
|
|
|
|
|
2000-02-17 00:16:01 +01:00
|
|
|
=item B<-passout arg>
|
2000-02-08 02:34:59 +01:00
|
|
|
|
2000-02-17 00:16:01 +01:00
|
|
|
the output file password source. For more information about the format of B<arg>
|
|
|
|
see the B<PASS PHRASE ARGUMENTS> section in L<openssl(1)|openssl(1)>.
|
2000-02-08 02:34:59 +01:00
|
|
|
|
1999-11-10 03:52:17 +01:00
|
|
|
=item B<-des|-des3|-idea>
|
|
|
|
|
|
|
|
These options encrypt the private key with the DES, triple DES, or the
|
2000-02-08 02:34:59 +01:00
|
|
|
IDEA ciphers respectively before outputting it. If none of these options is
|
|
|
|
specified no encryption is used. If encryption is used a pass phrase is prompted
|
2000-02-17 00:16:01 +01:00
|
|
|
for if it is not supplied via the B<-passout> argument.
|
1999-11-10 03:52:17 +01:00
|
|
|
|
|
|
|
=item B<-F4|-3>
|
|
|
|
|
|
|
|
the public exponent to use, either 65537 or 3. The default is 65537.
|
|
|
|
|
2000-01-16 00:19:22 +01:00
|
|
|
=item B<-rand file(s)>
|
1999-11-10 03:52:17 +01:00
|
|
|
|
|
|
|
a file or files containing random data used to seed the random number
|
2000-02-24 18:18:51 +01:00
|
|
|
generator, or an EGD socket (see L<RAND_egd(3)|RAND_egd(3)>).
|
|
|
|
Multiple files can be specified separated by a OS-dependent character.
|
2000-04-12 18:48:20 +02:00
|
|
|
The separator is B<;> for MS-Windows, B<,> for OpenVMS, and B<:> for
|
2000-02-24 18:18:51 +01:00
|
|
|
all others.
|
2003-01-30 23:02:27 +01:00
|
|
|
|
|
|
|
=item B<-engine id>
|
|
|
|
|
|
|
|
specifying an engine (by it's unique B<id> string) will cause B<req>
|
|
|
|
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 03:52:17 +01:00
|
|
|
|
|
|
|
=item B<numbits>
|
|
|
|
|
|
|
|
the size of the private key to generate in bits. This must be the last option
|
|
|
|
specified. The default is 512.
|
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
=head1 NOTES
|
|
|
|
|
|
|
|
RSA private key generation essentially involves the generation of two prime
|
|
|
|
numbers. When generating a private key various symbols will be output to
|
2000-02-17 00:16:01 +01: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
|
|
|
|
round of the Miller-Rabin primality test. A newline means that the number has
|
|
|
|
passed all the prime tests (the actual number depends on the key size).
|
1999-11-10 03:52:17 +01:00
|
|
|
|
|
|
|
Because key generation is a random process the time taken to generate a key
|
|
|
|
may vary somewhat.
|
|
|
|
|
|
|
|
=head1 BUGS
|
|
|
|
|
|
|
|
A quirk of the prime generation algorithm is that it cannot generate small
|
|
|
|
primes. Therefore the number of bits should not be less that 64. For typical
|
|
|
|
private keys this will not matter because for security reasons they will
|
|
|
|
be much larger (typically 1024 bits).
|
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2000-01-27 02:25:31 +01:00
|
|
|
L<gendsa(1)|gendsa(1)>
|
2000-03-18 23:00:26 +01:00
|
|
|
|
|
|
|
=cut
|
|
|
|
|