1 .\" Automatically generated by Pod::Man 2.12 (Pod::Simple 3.05)
4 .\" ========================================================================
5 .de Sh \" Subsection heading
13 .de Sp \" Vertical space (when we can't use .PP)
17 .de Vb \" Begin verbatim text
22 .de Ve \" End verbatim text
26 .\" Set up some character translations and predefined strings. \*(-- will
27 .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left
28 .\" double quote, and \*(R" will give a right double quote. \*(C+ will
29 .\" give a nicer C++. Capital omega is used to do unbreakable dashes and
30 .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff,
31 .\" nothing in troff, for use with C<>.
33 .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p'
37 . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch
38 . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch
51 .\" If the F register is turned on, we'll generate index entries on stderr for
52 .\" titles (.TH), headers (.SH), subsections (.Sh), items (.Ip), and index
53 .\" entries marked with X<> in POD. Of course, you'll have to process the
54 .\" output yourself in some meaningful fashion.
57 . tm Index:\\$1\t\\n%\t"\\$2"
63 .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2).
64 .\" Fear. Run. Save yourself. No user-serviceable parts.
65 . \" fudge factors for nroff and troff
74 . ds #H ((1u-(\\\\n(.fu%2u))*.13m)
80 . \" simple accents for nroff and troff
90 . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u"
91 . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u'
92 . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u'
93 . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u'
94 . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u'
95 . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u'
97 . \" troff and (daisy-wheel) nroff accents
98 .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V'
99 .ds 8 \h'\*(#H'\(*b\h'-\*(#H'
100 .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#]
101 .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H'
102 .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u'
103 .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#]
104 .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#]
105 .ds ae a\h'-(\w'a'u*4/10)'e
106 .ds Ae A\h'-(\w'A'u*4/10)'E
107 . \" corrections for vroff
108 .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u'
109 .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u'
110 . \" for low resolution devices (crt and lpr)
111 .if \n(.H>23 .if \n(.V>19 \
124 .\" ========================================================================
126 .IX Title "RSA_private_encrypt 3"
127 .TH RSA_private_encrypt 3 "2007-10-24" "0.9.8g" "OpenSSL"
128 .\" For nroff, turn off justification. Always turn off hyphenation; it makes
129 .\" way too many mistakes in technical documents.
133 RSA_private_encrypt, RSA_public_decrypt \- low level signature operations
135 .IX Header "SYNOPSIS"
137 \& #include <openssl/rsa.h>
139 \& int RSA_private_encrypt(int flen, unsigned char *from,
140 \& unsigned char *to, RSA *rsa, int padding);
142 \& int RSA_public_decrypt(int flen, unsigned char *from,
143 \& unsigned char *to, RSA *rsa, int padding);
146 .IX Header "DESCRIPTION"
147 These functions handle \s-1RSA\s0 signatures at a low level.
149 \&\fIRSA_private_encrypt()\fR signs the \fBflen\fR bytes at \fBfrom\fR (usually a
150 message digest with an algorithm identifier) using the private key
151 \&\fBrsa\fR and stores the signature in \fBto\fR. \fBto\fR must point to
152 \&\fBRSA_size(rsa)\fR bytes of memory.
154 \&\fBpadding\fR denotes one of the following modes:
155 .IP "\s-1RSA_PKCS1_PADDING\s0" 4
156 .IX Item "RSA_PKCS1_PADDING"
157 \&\s-1PKCS\s0 #1 v1.5 padding. This function does not handle the
158 \&\fBalgorithmIdentifier\fR specified in \s-1PKCS\s0 #1. When generating or
159 verifying \s-1PKCS\s0 #1 signatures, \fIRSA_sign\fR\|(3) and \fIRSA_verify\fR\|(3) should be
161 .IP "\s-1RSA_NO_PADDING\s0" 4
162 .IX Item "RSA_NO_PADDING"
163 Raw \s-1RSA\s0 signature. This mode should \fIonly\fR be used to implement
164 cryptographically sound padding modes in the application code.
165 Signing user data directly with \s-1RSA\s0 is insecure.
167 \&\fIRSA_public_decrypt()\fR recovers the message digest from the \fBflen\fR
168 bytes long signature at \fBfrom\fR using the signer's public key
169 \&\fBrsa\fR. \fBto\fR must point to a memory section large enough to hold the
170 message digest (which is smaller than \fBRSA_size(rsa) \-
171 11\fR). \fBpadding\fR is the padding mode that was used to sign the data.
173 .IX Header "RETURN VALUES"
174 \&\fIRSA_private_encrypt()\fR returns the size of the signature (i.e.,
175 RSA_size(rsa)). \fIRSA_public_decrypt()\fR returns the size of the
176 recovered message digest.
178 On error, \-1 is returned; the error codes can be
179 obtained by \fIERR_get_error\fR\|(3).
181 .IX Header "SEE ALSO"
182 \&\fIERR_get_error\fR\|(3), \fIrsa\fR\|(3),
183 \&\fIRSA_sign\fR\|(3), \fIRSA_verify\fR\|(3)
186 The \fBpadding\fR argument was added in SSLeay 0.8. \s-1RSA_NO_PADDING\s0 is
187 available since SSLeay 0.9.0.