src/linux/doc/man/keytool.1
author jjiang
Mon, 15 Oct 2018 22:47:03 +0800
changeset 52121 934969c63223
parent 47224 e81f9ee4df7f
permissions -rw-r--r--
8211978: Move testlibrary/jdk/testlibrary/SimpleSSLContext.java and testkeys to network testlibrary Summary: Move SimpleSSLContext.java and testkeys to test/lib/jdk/test/lib/net Reviewed-by: chegar
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
     1
'\" t
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
     2
.\" Copyright (c) 1998, 2015, Oracle and/or its affiliates. All rights reserved.
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
     3
.\" DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
     4
.\"
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
     5
.\" This code is free software; you can redistribute it and/or modify it
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
     6
.\" under the terms of the GNU General Public License version 2 only, as
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
     7
.\" published by the Free Software Foundation.
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
     8
.\"
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
     9
.\" This code is distributed in the hope that it will be useful, but WITHOUT
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    10
.\" ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    11
.\" FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    12
.\" version 2 for more details (a copy is included in the LICENSE file that
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    13
.\" accompanied this code).
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    14
.\"
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    15
.\" You should have received a copy of the GNU General Public License version
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    16
.\" 2 along with this work; if not, write to the Free Software Foundation,
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    17
.\" Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    18
.\"
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    19
.\" Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    20
.\" or visit www.oracle.com if you need additional information or have any
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    21
.\" questions.
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    22
.\"
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    23
.\"     Arch: generic
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    24
.\"     Software: JDK 8
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    25
.\"     Date: 03 March 2015
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    26
.\"     SectDesc: Security Tools
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    27
.\"     Title: keytool.1
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    28
.\"
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    29
.if n .pl 99999
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    30
.TH keytool 1 "03 March 2015" "JDK 8" "Security Tools"
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    31
.\" -----------------------------------------------------------------
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    32
.\" * Define some portability stuff
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    33
.\" -----------------------------------------------------------------
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    34
.\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    35
.\" http://bugs.debian.org/507673
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    36
.\" http://lists.gnu.org/archive/html/groff/2009-02/msg00013.html
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    37
.\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    38
.ie \n(.g .ds Aq \(aq
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    39
.el       .ds Aq '
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    40
.\" -----------------------------------------------------------------
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    41
.\" * set default formatting
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    42
.\" -----------------------------------------------------------------
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    43
.\" disable hyphenation
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    44
.nh
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    45
.\" disable justification (adjust text to left margin only)
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    46
.ad l
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    47
.\" -----------------------------------------------------------------
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    48
.\" * MAIN CONTENT STARTS HERE *
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
    49
.\" -----------------------------------------------------------------
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    51
.SH NAME    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    52
keytool \- Manages a keystore (database) of cryptographic keys, X\&.509 certificate chains, and trusted certificates\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    53
.SH SYNOPSIS    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    54
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    55
.nf     
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    57
\fBkeytool\fR [\fIcommands\fR]
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    58
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    59
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    60
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    61
\fIcommands\fR
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    62
See Commands\&. These commands are categorized by task as follows:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    63
.RS     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    64
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    65
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    66
Create or Add Data to the Keystore
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    67
.RS     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    68
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    69
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    70
-gencert
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    71
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    72
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    73
-genkeypair
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    74
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    75
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    76
-genseckey
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    77
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    78
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    79
-importcert
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    80
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    81
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    82
-importpassword
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    83
.RE     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    84
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    85
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    86
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    87
Import Contents From Another Keystore
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    88
.RS     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    89
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    90
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    91
-importkeystore
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    92
.RE     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    93
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    94
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    95
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    96
Generate Certificate Request
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    97
.RS     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    98
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
    99
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   100
-certreq
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   101
.RE     
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   102
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   103
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   104
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   105
Export Data
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   106
.RS     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   107
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   108
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   109
-exportcert
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   110
.RE     
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   111
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   112
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   113
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   114
Display Data
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   115
.RS     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   116
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   117
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   118
-list
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   119
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   120
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   121
-printcert
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   122
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   123
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   124
-printcertreq
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   125
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   126
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   127
-printcrl
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   128
.RE     
9573
c02ff5a7c67b 7043684: Update man pages for JDK 7 tools
bpatel
parents: 5865
diff changeset
   129
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   130
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   131
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   132
Manage the Keystore
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   133
.RS     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   134
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   135
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   136
-storepasswd
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   137
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   138
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   139
-keypasswd
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   140
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   141
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   142
-delete
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   143
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   144
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   145
-changealias
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   146
.RE     
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   147
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   148
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   149
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   150
Get Help
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   151
.RS     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   152
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   153
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   154
-help
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   155
.RE     
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   156
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   157
.RE     
9573
c02ff5a7c67b 7043684: Update man pages for JDK 7 tools
bpatel
parents: 5865
diff changeset
   158
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   159
.SH DESCRIPTION    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   160
The \f3keytool\fR command is a key and certificate management utility\&. It enables users to administer their own public/private key pairs and associated certificates for use in self-authentication (where the user authenticates himself or herself to other users and services) or data integrity and authentication services, using digital signatures\&. The \f3keytool\fR command also enables users to cache the public keys (in the form of certificates) of their communicating peers\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   161
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   162
A certificate is a digitally signed statement from one entity (person, company, and so on\&.), that says that the public key (and some other information) of some other entity has a particular value\&. (See Certificate\&.) When data is digitally signed, the signature can be verified to check the data integrity and authenticity\&. Integrity means that the data has not been modified or tampered with, and authenticity means the data comes from whoever claims to have created and signed it\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   163
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   164
The \f3keytool\fR command also enables users to administer secret keys and passphrases used in symmetric encryption and decryption (DES)\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   165
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   166
The \f3keytool\fR command stores the keys and certificates in a keystore\&. See KeyStore aliases\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   167
.SH COMMAND\ AND\ OPTION\ NOTES    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   168
See Commands for a listing and description of the various commands\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   169
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   170
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   171
All command and option names are preceded by a minus sign (-)\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   172
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   173
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   174
The options for each command can be provided in any order\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   175
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   176
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   177
All items not italicized or in braces or brackets are required to appear as is\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   178
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   179
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   180
Braces surrounding an option signify that a default value will be used when the option is not specified on the command line\&. See Option Defaults\&. Braces are also used around the \f3-v\fR, \f3-rfc\fR, and \f3-J\fR options, which only have meaning when they appear on the command line\&. They do not have any default values other than not existing\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   181
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   182
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   183
Brackets surrounding an option signify that the user is prompted for the values when the option is not specified on the command line\&. For the \f3-keypass\fR option, if you do not specify the option on the command line, then the \f3keytool\fR command first attempts to use the keystore password to recover the private/secret key\&. If this attempt fails, then the \f3keytool\fR command prompts you for the private/secret key password\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   184
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   185
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   186
Items in italics (option values) represent the actual values that must be supplied\&. For example, here is the format of the \f3-printcert\fR command:
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   187
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   188
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   189
\f3keytool \-printcert {\-file \fIcert_file\fR} {\-v}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   190
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   191
.sp     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   192
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   193
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   194
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   195
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   196
When you specify a \f3-printcert\fR command, replace \fIcert_file\fR with the actual file name, as follows: \f3keytool -printcert -file VScert\&.cer\fR
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   197
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   198
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   199
Option values must be put in quotation marks when they contain a blank (space)\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   200
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   201
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   202
The \f3-help\fR option is the default\&. The \f3keytool\fR command is the same as \f3keytool -help\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   203
.SH OPTION\ DEFAULTS    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   204
The following examples show the defaults for various option values\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   205
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   206
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   207
\f3\-alias "mykey"\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   208
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   209
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   210
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   211
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   212
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   213
\f3\-keyalg\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   214
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   215
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   216
\f3    "DSA" (when using \-genkeypair)\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   217
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   218
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   219
\f3    "DES" (when using \-genseckey)\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   220
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   221
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   222
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   223
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   224
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   225
\f3\-keysize\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   226
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   227
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   228
\f3    2048 (when using \-genkeypair and \-keyalg is "RSA")\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   229
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   230
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   231
\f3    1024 (when using \-genkeypair and \-keyalg is "DSA")\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   232
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   233
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   234
\f3    256 (when using \-genkeypair and \-keyalg is "EC")\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   235
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   236
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   237
\f3    56 (when using \-genseckey and \-keyalg is "DES")\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   238
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   239
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   240
\f3    168 (when using \-genseckey and \-keyalg is "DESede")\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   241
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   242
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   243
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   244
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   245
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   246
\f3\-validity 90\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   247
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   248
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   249
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   250
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   251
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   252
\f3\-keystore <the file named \&.keystore in the user\&'s home directory>\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   253
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   254
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   255
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   256
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   257
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   258
\f3\-storetype <the value of the "keystore\&.type" property in the\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   259
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   260
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   261
\f3    security properties file, which is returned by the static\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   262
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   263
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   264
\f3    getDefaultType method in java\&.security\&.KeyStore>\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   265
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   266
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   267
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   268
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   269
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   270
\f3\-file\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   271
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   272
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   273
\f3    stdin (if reading)\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   274
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   275
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   276
\f3    stdout (if writing)\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   277
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   278
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   279
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   280
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   281
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   282
\f3\-protected false\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   283
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   284
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   285
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   286
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   287
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   288
In generating a public/private key pair, the signature algorithm (\f3-sigalg\fR option) is derived from the algorithm of the underlying private key:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   289
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   290
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   291
If the underlying private key is of type DSA, then the \f3-sigalg\fR option defaults to SHA1withDSA\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   292
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   293
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   294
If the underlying private key is of type RSA, then the \f3-sigalg\fR option defaults to SHA256withRSA\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   295
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   296
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   297
If the underlying private key is of type EC, then the \f3-sigalg\fR option defaults to SHA256withECDSA\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   298
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   299
For a full list of \f3-keyalg\fR and \f3-sigalg\fR arguments, see Java Cryptography Architecture (JCA) Reference Guide at http://docs\&.oracle\&.com/javase/8/docs/technotes/guides/security/crypto/CryptoSpec\&.html#AppA
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   300
.SH COMMON\ OPTIONS    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   301
The \f3-v\fR option can appear for all commands except \f3-help\fR\&. When the \f3-v\fR option appears, it signifies verbose mode, which means that more information is provided in the output\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   302
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   303
There is also a \f3-Jjavaoption\fR argument that can appear for any command\&. When the \f3-Jjavaoption\fR appears, the specified \f3javaoption\fR string is passed directly to the Java interpreter\&. This option does not contain any spaces\&. It is useful for adjusting the execution environment or memory usage\&. For a list of possible interpreter options, type \f3java -h\fR or \f3java -X\fR at the command line\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   304
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   305
These options can appear for all commands operating on a keystore:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   306
.TP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   307
-storetype \fIstoretype\fR
2692
345bc8d65b19 6837214: Update JDK7 man pages
tbell
parents: 2
diff changeset
   308
.br
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   309
This qualifier specifies the type of keystore to be instantiated\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   310
.TP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   311
-keystore \fIkeystore\fR
2692
345bc8d65b19 6837214: Update JDK7 man pages
tbell
parents: 2
diff changeset
   312
.br
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   313
The keystore location\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   314
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   315
If the JKS \f3storetype\fR is used and a keystore file does not yet exist, then certain \f3keytool\fR commands can result in a new keystore file being created\&. For example, if \f3keytool -genkeypair\fR is called and the \f3-keystore\fR option is not specified, the default keystore file named \f3\&.keystore\fR in the user\&'s home directory is created when it does not already exist\&. Similarly, if the \f3-keystore ks_file\fR option is specified but ks_file does not exist, then it is created\&. For more information on the JKS \f3storetype\fR, see the \fIKeyStore Implementation\fR section in KeyStore aliases\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   316
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   317
Note that the input stream from the \f3-keystore\fR option is passed to the \f3KeyStore\&.load\fR method\&. If \f3NONE\fR is specified as the URL, then a null stream is passed to the \f3KeyStore\&.load\fR method\&. \f3NONE\fR should be specified if the keystore is not file-based\&. For example, when it resides on a hardware token device\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   318
.TP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   319
-storepass[:\fIenv\fR| :\fIfile\fR] argument
2692
345bc8d65b19 6837214: Update JDK7 man pages
tbell
parents: 2
diff changeset
   320
.br
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   321
The password that is used to protect the integrity of the keystore\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   322
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   323
If the modifier \f3env\fR or \f3file\fR is not specified, then the password has the \f3value\fR argument, which must be at least 6 characters long\&. Otherwise, the password is retrieved as follows:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   324
.RS     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   325
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   326
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   327
\f3env\fR: Retrieve the password from the environment variable named \f3argument\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   328
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   329
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   330
\f3file\fR: Retrieve the password from the file named argument\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   331
.RE     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   332
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   333
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   334
\fINote:\fR All other options that require passwords, such as \f3-keypass\fR, \f3-srckeypass\fR, -\f3destkeypass\fR, \f3-srcstorepass\fR, and \f3-deststorepass\fR, accept the \fIenv\fR and \fIfile\fR modifiers\&. Remember to separate the password option and the modifier with a colon (:)\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   335
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   336
The password must be provided to all commands that access the keystore contents\&. For such commands, when the \f3-storepass\fR option is not provided at the command line, the user is prompted for it\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   337
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   338
When retrieving information from the keystore, the password is optional\&. If no password is specified, then the integrity of the retrieved information cannot be verified and a warning is displayed\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   339
.TP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   340
-providerName \fIprovider_name\fR
2692
345bc8d65b19 6837214: Update JDK7 man pages
tbell
parents: 2
diff changeset
   341
.br
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   342
Used to identify a cryptographic service provider\&'s name when listed in the security properties file\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   343
.TP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   344
-providerClass \fIprovider_class_name\fR
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   345
.br
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   346
Used to specify the name of a cryptographic service provider\&'s master class file when the service provider is not listed in the security properties file\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   347
.TP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   348
-providerArg \fIprovider_arg\fR
2692
345bc8d65b19 6837214: Update JDK7 man pages
tbell
parents: 2
diff changeset
   349
.br
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   350
Used with the \f3-providerClass\fR option to represent an optional string input argument for the constructor of \f3provider_class_name\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   351
.TP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   352
-protected
2692
345bc8d65b19 6837214: Update JDK7 man pages
tbell
parents: 2
diff changeset
   353
.br
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   354
Either \f3true\fR or \f3false\fR\&. This value should be specified as \f3true\fR when a password must be specified by way of a protected authentication path such as a dedicated PIN reader\&.Because there are two keystores involved in the \f3-importkeystore\fR command, the following two options \f3-srcprotected\fR and -\f3destprotected\fR are provided for the source keystore and the destination keystore respectively\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   355
.TP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   356
-ext \fI{name{:critical} {=value}}\fR
2692
345bc8d65b19 6837214: Update JDK7 man pages
tbell
parents: 2
diff changeset
   357
.br
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   358
Denotes an X\&.509 certificate extension\&. The option can be used in \f3-genkeypair\fR and \f3-gencert\fR to embed extensions into the certificate generated, or in \f3-certreq\fR to show what extensions are requested in the certificate request\&. The option can appear multiple times\&. The \f3name\fR argument can be a supported extension name (see Named Extensions) or an arbitrary OID number\&. The \f3value\fR argument, when provided, denotes the argument for the extension\&. When \fIvalue\fR is omitted, that means that the default value of the extension or the extension requires no argument\&. The \f3:critical\fR modifier, when provided, means the extension\&'s \f3isCritical\fR attribute is \f3true\fR; otherwise, it is \f3false\fR\&. You can use \f3:c\fR in place of \f3:critical\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   359
.SH NAMED\ EXTENSIONS    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   360
The \f3keytool\fR command supports these named extensions\&. The names are not case-sensitive)\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   361
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   362
BC or BasicContraints
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   363
\fIValues\fR: The full form is: \f3ca:{true|false}[,pathlen:<len>]\fR or \f3<len>\fR, which is short for \f3ca:true,pathlen:<len>\fR\&. When <\f3len\fR> is omitted, you have \f3ca:true\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   364
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   365
KU or KeyUsage
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   366
\fIValues\fR: \f3usage\fR(,\f3usage\fR)*, where \fIusage\fR can be one of \f3digitalSignature\fR, \f3nonRepudiation\fR (contentCommitment), \f3keyEncipherment\fR, \f3dataEncipherment\fR, \f3keyAgreement\fR, \f3keyCertSign\fR, \f3cRLSign\fR, \f3encipherOnly\fR, \f3decipherOnly\fR\&. The \fIusage\fR argument can be abbreviated with the first few letters (\f3dig\fR for \f3digitalSignature\fR) or in camel-case style (\f3dS\fR for \f3digitalSignature\fR or \f3cRLS\fR for \f3cRLSign\fR), as long as no ambiguity is found\&. The \f3usage\fR values are case-sensitive\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   367
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   368
EKU or ExtendedKeyUsage
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   369
\fIValues\fR: \f3usage\fR(,\f3usage\fR)*, where \fIusage\fR can be one of \f3anyExtendedKeyUsage\fR, \f3serverAuth\fR, \f3clientAuth\fR, \f3codeSigning\fR, \f3emailProtection\fR, \f3timeStamping\fR, \f3OCSPSigning\fR, or any \fIOID string\fR\&. The \fIusage\fR argument can be abbreviated with the first few letters or in camel-case style, as long as no ambiguity is found\&. The \f3usage\fR values are case-sensitive\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   370
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   371
SAN or SubjectAlternativeName
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   372
\fIValues\fR: \f3type\fR:\f3value\fR(,t\f3ype:value\fR)*, where \f3type\fR can be \f3EMAIL\fR, \f3URI\fR, \f3DNS\fR, \f3IP\fR, or \f3OID\fR\&. The \f3value\fR argument is the string format value for the \f3type\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   373
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   374
IAN or IssuerAlternativeName
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   375
\fIValues\fR: Same as \f3SubjectAlternativeName\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   376
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   377
SIA or SubjectInfoAccess
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   378
\fIValues\fR: \f3method\fR:\f3location-type\fR:\f3location-value\fR (,\f3method:location-type\fR:\f3location-value\fR)*, where \f3method\fR can be \f3timeStamping\fR, \f3caRepository\fR or any OID\&. The \f3location-type\fR and \f3location-value\fR arguments can be any \f3type\fR:\f3value\fR supported by the \f3SubjectAlternativeName\fR extension\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   379
.TP     
2692
345bc8d65b19 6837214: Update JDK7 man pages
tbell
parents: 2
diff changeset
   380
AIA or AuthorityInfoAccess
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   381
\fIValues\fR: Same as \f3SubjectInfoAccess\fR\&. The \f3method\fR argument can be \f3ocsp\fR,\f3caIssuers\fR, or any OID\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   382
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   383
When \f3name\fR is OID, the value is the hexadecimal dumped DER encoding of the \f3extnValue\fR for the extension excluding the OCTET STRING type and length bytes\&. Any extra character other than standard hexadecimal numbers (0-9, a-f, A-F) are ignored in the HEX string\&. Therefore, both 01:02:03:04 and 01020304 are accepted as identical values\&. When there is no value, the extension has an empty value field\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   384
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   385
A special name \f3honored\fR, used in \f3-gencert\fR only, denotes how the extensions included in the certificate request should be honored\&. The value for this name is a comma separated list of \f3all\fR (all requested extensions are honored), \f3name{:[critical|non-critical]}\fR (the named extension is honored, but using a different \f3isCritical\fR attribute) and \f3-name\fR (used with \f3all\fR, denotes an exception)\&. Requested extensions are not honored by default\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   386
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   387
If, besides the\f3-ext honored\fR option, another named or OID \f3-ext\fR option is provided, this extension is added to those already honored\&. However, if this name (or OID) also appears in the honored value, then its value and criticality overrides the one in the request\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   388
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   389
The \f3subjectKeyIdentifier\fR extension is always created\&. For non-self-signed certificates, the \f3authorityKeyIdentifier\fR is created\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   390
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   391
\fINote:\fR Users should be aware that some combinations of extensions (and other certificate fields) may not conform to the Internet standard\&. See Certificate Conformance Warning\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   392
.SH COMMANDS    
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   393
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   394
-gencert
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   395
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   396
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   397
\f3{\-rfc} {\-infile \fIinfile\fR} {\-outfile \fIoutfile\fR} {\-alias \fIalias\fR} {\-sigalg \fIsigalg\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   398
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   399
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   400
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   401
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   402
\f3{\-dname \fIdname\fR} {\-startdate \fIstartdate\fR {\-ext \fIext\fR}* {\-validity \fIvalDays\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   403
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   404
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   405
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   406
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   407
\f3[\-keypass \fIkeypass\fR] {\-keystore \fIkeystore\fR} [\-storepass \fIstorepass\fR]\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   408
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   409
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   410
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   411
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   412
\f3{\-storetype \fIstoretype\fR} {\-providername \fIprovider_name\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   413
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   414
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   415
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   416
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   417
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   418
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   419
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   420
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   421
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   422
\f3{\-v} {\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   423
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   424
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   425
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   426
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   427
Generates a certificate as a response to a certificate request file (which can be created by the \f3keytool\fR\f3-certreq\fR command)\&. The command reads the request from \fIinfile\fR (if omitted, from the standard input), signs it using alias\&'s private key, and outputs the X\&.509 certificate into \fIoutfile\fR (if omitted, to the standard output)\&. When\f3-rfc\fR is specified, the output format is Base64-encoded PEM; otherwise, a binary DER is created\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   428
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   429
The \f3sigalg\fR value specifies the algorithm that should be used to sign the certificate\&. The \f3startdate\fR argument is the start time and date that the certificate is valid\&. The \f3valDays\fR argument tells the number of days for which the certificate should be considered valid\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   430
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   431
When \f3dname\fR is provided, it is used as the subject of the generated certificate\&. Otherwise, the one from the certificate request is used\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   432
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   433
The \f3ext\fR value shows what X\&.509 extensions will be embedded in the certificate\&. Read Common Options for the grammar of \f3-ext\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   434
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   435
The \f3-gencert\fR option enables you to create certificate chains\&. The following example creates a certificate, \f3e1\fR, that contains three certificates in its certificate chain\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   436
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   437
The following commands creates four key pairs named \f3ca\fR, \f3ca1\fR, \f3ca2\fR, and \f3e1\fR:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   438
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   439
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   440
\f3keytool \-alias ca \-dname CN=CA \-genkeypair\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   441
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   442
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   443
\f3keytool \-alias ca1 \-dname CN=CA \-genkeypair\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   444
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   445
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   446
\f3keytool \-alias ca2 \-dname CN=CA \-genkeypair\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   447
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   448
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   449
\f3keytool \-alias e1 \-dname CN=E1 \-genkeypair\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   450
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   451
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   452
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   453
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   454
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   455
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   456
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   457
The following two commands create a chain of signed certificates; \f3ca\fR signs \f3ca1\fR and \f3ca1\fR signs \f3ca2\fR, all of which are self-issued:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   458
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   459
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   460
\f3keytool \-alias ca1 \-certreq |\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   461
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   462
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   463
\f3    keytool \-alias ca \-gencert \-ext san=dns:ca1 |\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   464
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   465
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   466
\f3    keytool \-alias ca1 \-importcert\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   467
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   468
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   469
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   470
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   471
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   472
\f3keytool \-alias ca2 \-certreq |\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   473
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   474
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   475
\f3    $KT \-alias ca1 \-gencert \-ext san=dns:ca2 |\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   476
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   477
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   478
\f3    $KT \-alias ca2 \-importcert\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   479
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   480
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   481
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   482
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   483
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   484
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   485
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   486
The following command creates the certificate \f3e1\fR and stores it in the file \f3e1\&.cert\fR, which is signed by \f3ca2\fR\&. As a result, \f3e1\fR should contain \f3ca\fR, \f3ca1\fR, and \f3ca2\fR in its certificate chain:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   487
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   488
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   489
\f3keytool \-alias e1 \-certreq | keytool \-alias ca2 \-gencert > e1\&.cert\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   490
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   491
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   492
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   493
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   494
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   495
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   496
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   497
-genkeypair
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   498
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   499
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   500
\f3{\-alias \fIalias\fR} {\-keyalg \fIkeyalg\fR} {\-keysize \fIkeysize\fR} {\-sigalg \fIsigalg\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   501
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   502
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   503
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   504
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   505
\f3[\-dname \fIdname\fR] [\-keypass \fIkeypass\fR] {\-startdate \fIvalue\fR} {\-ext \fIext\fR}*\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   506
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   507
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   508
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   509
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   510
\f3{\-validity \fIvalDays\fR} {\-storetype \fIstoretype\fR} {\-keystore \fIkeystore\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   511
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   512
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   513
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   514
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   515
\f3[\-storepass \fIstorepass\fR]\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   516
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   517
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   518
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   519
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   520
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   521
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   522
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   523
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   524
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   525
\f3{\-v} {\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   526
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   527
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   528
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   529
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   530
Generates a key pair (a public key and associated private key)\&. Wraps the public key into an X\&.509 v3 self-signed certificate, which is stored as a single-element certificate chain\&. This certificate chain and the private key are stored in a new keystore entry identified by alias\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   531
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   532
The \f3keyalg\fR value specifies the algorithm to be used to generate the key pair, and the \f3keysize\fR value specifies the size of each key to be generated\&. The \f3sigalg\fR value specifies the algorithm that should be used to sign the self-signed certificate\&. This algorithm must be compatible with the \f3keyalg\fR value\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   533
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   534
The \f3dname\fR value specifies the X\&.500 Distinguished Name to be associated with the value of \f3alias\fR, and is used as the issuer and subject fields in the self-signed certificate\&. If no distinguished name is provided at the command line, then the user is prompted for one\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   535
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   536
The value of \f3keypass\fR is a password used to protect the private key of the generated key pair\&. If no password is provided, then the user is prompted for it\&. If you press \fIthe Return key\fR at the prompt, then the key password is set to the same password as the keystore password\&. The \f3keypass\fR value must be at least 6 characters\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   537
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   538
The value of \f3startdate\fR specifies the issue time of the certificate, also known as the "Not Before" value of the X\&.509 certificate\&'s Validity field\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   539
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   540
The option value can be set in one of these two forms:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   541
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   542
\f3([+-]nnn[ymdHMS])+\fR
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   543
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   544
\f3[yyyy/mm/dd] [HH:MM:SS]\fR
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   545
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   546
With the first form, the issue time is shifted by the specified value from the current time\&. The value is a concatenation of a sequence of subvalues\&. Inside each subvalue, the plus sign (+) means shift forward, and the minus sign (-) means shift backward\&. The time to be shifted is \f3nnn\fR units of years, months, days, hours, minutes, or seconds (denoted by a single character of \f3y\fR, \f3m\fR, \f3d\fR, \f3H\fR, \f3M\fR, or \f3S\fR respectively)\&. The exact value of the issue time is calculated using the \f3java\&.util\&.GregorianCalendar\&.add(int field, int amount)\fR method on each subvalue, from left to right\&. For example, by specifying, the issue time will be:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   547
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   548
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   549
\f3Calendar c = new GregorianCalendar();\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   550
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   551
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   552
\f3c\&.add(Calendar\&.YEAR, \-1);\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   553
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   554
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   555
\f3c\&.add(Calendar\&.MONTH, 1);\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   556
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   557
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   558
\f3c\&.add(Calendar\&.DATE, \-1);\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   559
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   560
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   561
\f3return c\&.getTime()\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   562
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   563
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   564
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   565
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   566
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   567
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   568
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   569
With the second form, the user sets the exact issue time in two parts, year/month/day and hour:minute:second (using the local time zone)\&. The user can provide only one part, which means the other part is the same as the current date (or time)\&. The user must provide the exact number of digits as shown in the format definition (padding with 0 when shorter)\&. When both the date and time are provided, there is one (and only one) space character between the two parts\&. The hour should always be provided in 24 hour format\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   570
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   571
When the option is not provided, the start date is the current time\&. The option can be provided at most once\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   572
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   573
The value of \f3valDays\fR specifies the number of days (starting at the date specified by \f3-startdate\fR, or the current date when \f3-startdate\fR is not specified) for which the certificate should be considered valid\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   574
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   575
This command was named \f3-genkey\fR in earlier releases\&. The old name is still supported in this release\&. The new name, \f3-genkeypair\fR, is preferred going forward\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   576
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   577
-genseckey
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   578
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   579
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   580
\f3{\-alias \fIalias\fR} {\-keyalg \fIkeyalg\fR} {\-keysize \fIkeysize\fR} [\-keypass \fIkeypass\fR]\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   581
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   582
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   583
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   584
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   585
\f3{\-storetype \fIstoretype\fR} {\-keystore \fIkeystore\fR} [\-storepass \fIstorepass\fR]\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   586
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   587
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   588
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   589
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   590
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}} {\-v}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   591
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   592
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   593
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   594
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   595
\f3{\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   596
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   597
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   598
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   599
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   600
Generates a secret key and stores it in a new \f3KeyStore\&.SecretKeyEntry\fR identified by \f3alias\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   601
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   602
The value of \f3keyalg\fR specifies the algorithm to be used to generate the secret key, and the value of \f3keysize\fR specifies the size of the key to be generated\&. The \f3keypass\fR value is a password that protects the secret key\&. If no password is provided, then the user is prompted for it\&. If you press the Return key at the prompt, then the key password is set to the same password that is used for the \f3keystore\fR\&. The \f3keypass\fR value must be at least 6 characters\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   603
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   604
-importcert
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   605
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   606
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   607
\f3{\-alias \fIalias\fR} {\-file \fIcert_file\fR} [\-keypass \fIkeypass\fR] {\-noprompt} {\-trustcacerts}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   608
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   609
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   610
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   611
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   612
\f3{\-storetype \fIstoretype\fR} {\-keystore \fIkeystore\fR} [\-storepass \fIstorepass\fR]\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   613
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   614
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   615
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   616
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   617
\f3{\-providerName \fIprovider_name\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   618
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   619
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   620
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   621
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   622
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   623
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   624
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   625
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   626
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   627
\f3{\-v} {\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   628
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   629
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   630
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   631
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   632
Reads the certificate or certificate chain (where the latter is supplied in a PKCS#7 formatted reply or a sequence of X\&.509 certificates) from the file \f3cert_file\fR, and stores it in the \f3keystore\fR entry identified by \f3alias\fR\&. If no file is specified, then the certificate or certificate chain is read from \f3stdin\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   633
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   634
The \f3keytool\fR command can import X\&.509 v1, v2, and v3 certificates, and PKCS#7 formatted certificate chains consisting of certificates of that type\&. The data to be imported must be provided either in binary encoding format or in printable encoding format (also known as Base64 encoding) as defined by the Internet RFC 1421 standard\&. In the latter case, the encoding must be bounded at the beginning by a string that starts with \f3-\fR\f3----BEGIN\fR, and bounded at the end by a string that starts with \f3-----END\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   635
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   636
You import a certificate for two reasons: To add it to the list of trusted certificates, and to import a certificate reply received from a certificate authority (CA) as the result of submitting a Certificate Signing Request to that CA (see the \f3-certreq\fR option in Commands)\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   637
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   638
Which type of import is intended is indicated by the value of the \f3-alias\fR option\&. If the alias does not point to a key entry, then the \f3keytool\fR command assumes you are adding a trusted certificate entry\&. In this case, the alias should not already exist in the keystore\&. If the alias does already exist, then the \f3keytool\fR command outputs an error because there is already a trusted certificate for that alias, and does not import the certificate\&. If the alias points to a key entry, then the \f3keytool\fR command assumes you are importing a certificate reply\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   639
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   640
-importpassword
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   641
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   642
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   643
\f3{\-alias \fIalias\fR} [\-keypass \fIkeypass\fR] {\-storetype \fIstoretype\fR} {\-keystore \fIkeystore\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   644
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   645
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   646
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   647
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   648
\f3[\-storepass \fIstorepass\fR]\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   649
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   650
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   651
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   652
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   653
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   654
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   655
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   656
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   657
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   658
\f3{\-v} {\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   659
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   660
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   661
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   662
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   663
Imports a passphrase and stores it in a new \f3KeyStore\&.SecretKeyEntry\fR identified by \f3alias\fR\&. The passphrase may be supplied via the standard input stream; otherwise the user is prompted for it\&. \f3keypass\fR is a password used to protect the imported passphrase\&. If no password is provided, the user is prompted for it\&. If you press the Return key at the prompt, the key password is set to the same password as that used for the \f3keystore\fR\&. \f3keypass\fR must be at least 6 characters long\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   664
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   665
-importkeystore
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   666
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   667
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   668
\f3{\-srcstoretype \fIsrcstoretype\fR} {\-deststoretype \fIdeststoretype\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   669
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   670
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   671
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   672
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   673
\f3[\-srcstorepass \fIsrcstorepass\fR] [\-deststorepass \fIdeststorepass\fR] {\-srcprotected}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   674
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   675
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   676
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   677
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   678
\f3{\-destprotected} \fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   679
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   680
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   681
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   682
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   683
\f3{\-srcalias \fIsrcalias\fR {\-destalias \fIdestalias\fR} [\-srckeypass \fIsrckeypass\fR]} \fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   684
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   685
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   686
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   687
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   688
\f3[\-destkeypass \fIdestkeypass\fR] {\-noprompt}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   689
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   690
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   691
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   692
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   693
\f3{\-srcProviderName \fIsrc_provider_name\fR} {\-destProviderName \fIdest_provider_name\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   694
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   695
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   696
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   697
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   698
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}} {\-v}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   699
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   700
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   701
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   702
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   703
\f3{\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   704
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   705
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   706
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   707
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   708
Imports a single entry or all entries from a source keystore to a destination keystore\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   709
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   710
When the \f3-srcalias\fR option is provided, the command imports the single entry identified by the alias to the destination keystore\&. If a destination alias is not provided with \f3destalias\fR, then \f3srcalias\fR is used as the destination alias\&. If the source entry is protected by a password, then \f3srckeypass\fR is used to recover the entry\&. If \fIsrckeypass\fR is not provided, then the \f3keytool\fR command attempts to use \f3srcstorepass\fR to recover the entry\&. If \f3srcstorepass\fR is either not provided or is incorrect, then the user is prompted for a password\&. The destination entry is protected with \f3destkeypass\fR\&. If \f3destkeypass\fR is not provided, then the destination entry is protected with the source entry password\&. For example, most third-party tools require \f3storepass\fR and \f3keypass\fR in a PKCS #12 keystore to be the same\&. In order to create a PKCS #12 keystore for these tools, always specify a \f3-destkeypass\fR to be the same as \f3-deststorepass\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   711
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   712
If the \f3-srcalias\fR option is not provided, then all entries in the source keystore are imported into the destination keystore\&. Each destination entry is stored under the alias from the source entry\&. If the source entry is protected by a password, then \f3srcstorepass\fR is used to recover the entry\&. If \f3srcstorepass\fR is either not provided or is incorrect, then the user is prompted for a password\&. If a source keystore entry type is not supported in the destination keystore, or if an error occurs while storing an entry into the destination keystore, then the user is prompted whether to skip the entry and continue or to quit\&. The destination entry is protected with the source entry password\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   713
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   714
If the destination alias already exists in the destination keystore, then the user is prompted to either overwrite the entry or to create a new entry under a different alias name\&.
2692
345bc8d65b19 6837214: Update JDK7 man pages
tbell
parents: 2
diff changeset
   715
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   716
If the \f3-noprompt\fR option is provided, then the user is not prompted for a new destination alias\&. Existing entries are overwritten with the destination alias name\&. Entries that cannot be imported are skipped and a warning is displayed\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   717
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   718
-printcertreq
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   719
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   720
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   721
\f3{\-file \fIfile\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   722
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   723
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   724
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   725
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   726
Prints the content of a PKCS #10 format certificate request, which can be generated by the \f3keytool\fR\f3-certreq\fR command\&. The command reads the request from file\&. If there is no file, then the request is read from the standard input\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   727
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   728
-certreq
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   729
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   730
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   731
\f3{\-alias \fIalias\fR} {\-dname \fIdname\fR} {\-sigalg \fIsigalg\fR} {\-file \fIcertreq_file\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   732
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   733
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   734
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   735
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   736
\f3[\-keypass \fIkeypass\fR] {\-storetype \fIstoretype\fR} {\-keystore \fIkeystore\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   737
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   738
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   739
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   740
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   741
\f3[\-storepass \fIstorepass\fR] {\-providerName \fIprovider_name\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   742
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   743
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   744
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   745
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   746
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   747
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   748
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   749
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   750
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   751
\f3{\-v} {\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   752
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   753
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   754
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   755
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   756
Generates a Certificate Signing Request (CSR) using the PKCS #10 format\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   757
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   758
A CSR is intended to be sent to a certificate authority (CA)\&. The CA authenticates the certificate requestor (usually off-line) and will return a certificate or certificate chain, used to replace the existing certificate chain (which initially consists of a self-signed certificate) in the keystore\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   759
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   760
The private key associated with alias is used to create the PKCS #10 certificate request\&. To access the private key, the correct password must be provided\&. If \f3keypass\fR is not provided at the command line and is different from the password used to protect the integrity of the keystore, then the user is prompted for it\&. If \f3dname\fR is provided, then it is used as the subject in the CSR\&. Otherwise, the X\&.500 Distinguished Name associated with alias is used\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   761
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   762
The \f3sigalg\fR value specifies the algorithm that should be used to sign the CSR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   763
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   764
The CSR is stored in the file certreq_file\&. If no file is specified, then the CSR is output to \f3stdout\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   765
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   766
Use the \f3importcert\fR command to import the response from the CA\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   767
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   768
-exportcert
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   769
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   770
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   771
\f3{\-alias \fIalias\fR} {\-file \fIcert_file\fR} {\-storetype \fIstoretype\fR} {\-keystore \fIkeystore\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   772
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   773
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   774
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   775
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   776
\f3[\-storepass \fIstorepass\fR] {\-providerName \fIprovider_name\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   777
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   778
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   779
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   780
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   781
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   782
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   783
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   784
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   785
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   786
\f3{\-rfc} {\-v} {\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   787
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   788
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   789
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   790
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   791
Reads from the keystore the certificate associated with \fIalias\fR and stores it in the cert_file file\&. When no file is specified, the certificate is output to \f3stdout\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   792
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   793
The certificate is by default output in binary encoding\&. If the \f3-rfc\fR option is specified, then the output in the printable encoding format defined by the Internet RFC 1421 Certificate Encoding Standard\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   794
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   795
If \f3alias\fR refers to a trusted certificate, then that certificate is output\&. Otherwise, \f3alias\fR refers to a key entry with an associated certificate chain\&. In that case, the first certificate in the chain is returned\&. This certificate authenticates the public key of the entity addressed by \f3alias\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   796
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   797
This command was named \f3-export\fR in earlier releases\&. The old name is still supported in this release\&. The new name, \f3-exportcert\fR, is preferred going forward\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   798
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   799
-list
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   800
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   801
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   802
\f3{\-alias \fIalias\fR} {\-storetype \fIstoretype\fR} {\-keystore \fIkeystore\fR} [\-storepass \fIstorepass\fR]\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   803
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   804
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   805
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   806
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   807
\f3{\-providerName \fIprovider_name\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   808
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   809
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   810
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   811
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   812
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   813
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   814
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   815
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   816
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   817
\f3{\-v | \-rfc} {\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   818
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   819
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   820
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   821
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   822
Prints to \f3stdout\fR the contents of the keystore entry identified by \f3alias\fR\&. If no \f3alias\fR is specified, then the contents of the entire keystore are printed\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   823
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   824
This command by default prints the SHA1 fingerprint of a certificate\&. If the \f3-v\fR option is specified, then the certificate is printed in human-readable format, with additional information such as the owner, issuer, serial number, and any extensions\&. If the \f3-rfc\fR option is specified, then the certificate contents are printed using the printable encoding format, as defined by the Internet RFC 1421 Certificate Encoding Standard\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   825
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   826
You cannot specify both \f3-v\fR and \f3-rfc\fR\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   827
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   828
-printcert
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   829
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   830
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   831
\f3{\-file \fIcert_file\fR | \-sslserver \fIhost\fR[:\fIport\fR]} {\-jarfile \fIJAR_file\fR {\-rfc} {\-v}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   832
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   833
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   834
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   835
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   836
\f3{\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   837
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   838
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   839
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   840
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   841
Reads the certificate from the file cert_file, the SSL server located at host:port, or the signed JAR file \f3JAR_file\fR (with the \f3-jarfile\fR option and prints its contents in a human-readable format\&. When no port is specified, the standard HTTPS port 443 is assumed\&. Note that \f3-sslserver\fR and -file options cannot be provided at the same time\&. Otherwise, an error is reported\&. If neither option is specified, then the certificate is read from \f3stdin\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   842
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   843
When\f3-rfc\fR is specified, the \f3keytool\fR command prints the certificate in PEM mode as defined by the Internet RFC 1421 Certificate Encoding standard\&. See Internet RFC 1421 Certificate Encoding Standard\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   844
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   845
If the certificate is read from a file or \f3stdin\fR, then it might be either binary encoded or in printable encoding format, as defined by the RFC 1421 Certificate Encoding standard\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   846
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   847
If the SSL server is behind a firewall, then the \f3-J-Dhttps\&.proxyHost=proxyhost\fR and \f3-J-Dhttps\&.proxyPort=proxyport\fR options can be specified on the command line for proxy tunneling\&. See Java Secure Socket Extension (JSSE) Reference Guide at http://docs\&.oracle\&.com/javase/8/docs/technotes/guides/security/jsse/JSSERefGuide\&.html
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   848
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   849
\fINote:\fR This option can be used independently of a keystore\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   850
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   851
-printcrl
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   852
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   853
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   854
\f3\-file \fIcrl_\fR {\-v}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   855
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   856
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   857
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   858
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   859
Reads the Certificate Revocation List (CRL) from the file \f3crl_\fR\&. A CRL is a list of digital certificates that were revoked by the CA that issued them\&. The CA generates the \f3crl_\fR file\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   860
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   861
\fINote:\fR This option can be used independently of a keystore\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   862
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   863
-storepasswd
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   864
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   865
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   866
\f3[\-new \fInew_storepass\fR] {\-storetype \fIstoretype\fR} {\-keystore \fIkeystore\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   867
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   868
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   869
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   870
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   871
\f3[\-storepass \fIstorepass\fR] {\-providerName \fIprovider_name\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   872
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   873
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   874
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   875
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   876
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   877
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   878
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   879
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   880
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   881
\f3{\-v} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   882
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   883
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   884
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   885
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   886
Changes the password used to protect the integrity of the keystore contents\&. The new password is \f3new_storepass\fR, which must be at least 6 characters\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   887
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   888
-keypasswd
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   889
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   890
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   891
\f3{\-alias \fIalias\fR} [\-keypass \fIold_keypass\fR] [\-new \fInew_keypass\fR] {\-storetype \fIstoretype\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   892
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   893
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   894
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   895
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   896
\f3{\-keystore \fIkeystore\fR} [\-storepass \fIstorepass\fR] {\-providerName \fIprovider_name\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   897
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   898
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   899
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   900
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   901
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}} {\-v}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   902
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   903
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   904
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   905
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   906
\f3{\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   907
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   908
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   909
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   910
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   911
Changes the password under which the private/secret key identified by \f3alias\fR is protected, from \f3old_keypass\fR to \f3new_keypass\fR, which must be at least 6 characters\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   912
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   913
If the \f3-keypass\fR option is not provided at the command line, and the key password is different from the keystore password, then the user is prompted for it\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   914
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   915
If the \f3-new\fR option is not provided at the command line, then the user is prompted for it
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   916
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   917
-delete
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   918
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   919
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   920
\f3[\-alias \fIalias\fR] {\-storetype \fIstoretype\fR} {\-keystore \fIkeystore\fR} [\-storepass \fIstorepass\fR]\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   921
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   922
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   923
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   924
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   925
\f3{\-providerName \fIprovider_name\fR}  \fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   926
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   927
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   928
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   929
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   930
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   931
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   932
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   933
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   934
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   935
\f3{\-v} {\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   936
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   937
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   938
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   939
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   940
Deletes from the keystore the entry identified by \f3alias\fR\&. The user is prompted for the alias, when no alias is provided at the command line\&.
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   941
.TP     
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   942
-changealias
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   943
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   944
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   945
\f3{\-alias \fIalias\fR} [\-destalias \fIdestalias\fR] [\-keypass \fIkeypass\fR] {\-storetype \fIstoretype\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   946
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   947
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   948
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   949
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   950
\f3{\-keystore \fIkeystore\fR} [\-storepass \fIstorepass\fR] {\-providerName \fIprovider_name\fR}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   951
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   952
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   953
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   954
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   955
\f3{\-providerClass \fIprovider_class_name\fR {\-providerArg \fIprovider_arg\fR}} {\-v}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   956
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   957
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   958
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   959
.nf     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   960
\f3{\-protected} {\-Jjavaoption}\fP
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   961
.fi     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   962
.sp     
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
   963
9573
c02ff5a7c67b 7043684: Update man pages for JDK 7 tools
bpatel
parents: 5865
diff changeset
   964
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   965
Move an existing keystore entry from the specified \f3alias\fR to a new alias, \f3destalias\fR\&. If no destination alias is provided, then the command prompts for one\&. If the original entry is protected with an entry password, then the password can be supplied with the \f3-keypass\fR option\&. If no key password is provided, then the \f3storepass\fR (if provided) is attempted first\&. If the attempt fails, then the user is prompted for a password\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   966
.TP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   967
-help
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   968
.br
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   969
Lists the basic commands and their options\&.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   970
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   971
For more information about a specific command, enter the following, where \f3command_name\fR is the name of the command: \f3keytool -command_name -help\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   972
.SH EXAMPLES    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   973
This example walks through the sequence of steps to create a keystore for managing public/private key pair and certificates from trusted entities\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   974
.SS GENERATE\ THE\ KEY\ PAIR    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   975
First, create a keystore and generate the key pair\&. You can use a command such as the following typed as a single line:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   976
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   977
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   978
\f3keytool \-genkeypair \-dname "cn=Mark Jones, ou=Java, o=Oracle, c=US"\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   979
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   980
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   981
\f3    \-alias business \-keypass <new password for private key>\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   982
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   983
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   984
\f3    \-keystore /working/mykeystore\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   985
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   986
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   987
\f3    \-storepass <new password for keystore> \-validity 180\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   988
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   989
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   990
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   991
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   992
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   993
The command creates the keystore named \f3mykeystore\fR in the working directory (assuming it does not already exist), and assigns it the password specified by \f3<new password for keystore>\fR\&. It generates a public/private key pair for the entity whose distinguished name has a common name of Mark Jones, organizational unit of Java, organization of Oracle and two-letter country code of US\&. It uses the default DSA key generation algorithm to create the keys; both are 1024 bits\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   994
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   995
The command uses the default SHA1withDSA signature algorithm to create a self-signed certificate that includes the public key and the distinguished name information\&. The certificate is valid for 180 days, and is associated with the private key in a keystore entry referred to by the alias \f3business\fR\&. The private key is assigned the password specified by \f3<new password for private key>\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   996
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   997
The command is significantly shorter when the option defaults are accepted\&. In this case, no options are required, and the defaults are used for unspecified options that have default values\&. You are prompted for any required values\&. You could have the following:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   998
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
   999
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1000
\f3keytool \-genkeypair\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1001
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1002
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1003
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1004
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1005
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1006
In this case, a keystore entry with the alias \f3mykey\fR is created, with a newly generated key pair and a certificate that is valid for 90 days\&. This entry is placed in the keystore named \f3\&.keystore\fR in your home directory\&. The keystore is created when it does not already exist\&. You are prompted for the distinguished name information, the keystore password, and the private key password\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1007
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1008
The rest of the examples assume you executed the \f3-genkeypair\fR command without options specified, and that you responded to the prompts with values equal to those specified in the first \f3-genkeypair\fR command\&. For example, a distinguished name of \f3cn=Mark Jones\fR, \f3ou=Java\fR, \f3o=Oracle\fR, \f3c=US\fR)\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1009
.SS REQUEST\ A\ SIGNED\ CERTIFICATE\ FROM\ A\ CA    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1010
Generating the key pair created a self-signed certificate\&. A certificate is more likely to be trusted by others when it is signed by a Certification Authority (CA)\&. To get a CA signature, first generate a Certificate Signing Request (CSR), as follows:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1011
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1012
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1013
\f3keytool \-certreq \-file MarkJ\&.csr\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1014
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1015
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1016
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1017
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1018
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1019
This creates a CSR for the entity identified by the default alias \f3mykey\fR and puts the request in the file named MarkJ\&.csr\&. Submit this file to a CA, such as VeriSign\&. The CA authenticates you, the requestor (usually off-line), and returns a certificate, signed by them, authenticating your public key\&. In some cases, the CA returns a chain of certificates, each one authenticating the public key of the signer of the previous certificate in the chain\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1020
.SS IMPORT\ A\ CERTIFICATE\ FOR\ THE\ CA    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1021
You now need to replace the self-signed certificate with a certificate chain, where each certificate in the chain authenticates the public key of the signer of the previous certificate in the chain, up to a root CA\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1022
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1023
Before you import the certificate reply from a CA, you need one or more trusted certificates in your keystore or in the \f3cacerts\fR keystore file\&. See \f3-importcert\fR in Commands\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1024
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1025
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1026
If the certificate reply is a certificate chain, then you need the top certificate of the chain\&. The root CA certificate that authenticates the public key of the CA\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1027
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1028
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1029
If the certificate reply is a single certificate, then you need a certificate for the issuing CA (the one that signed it)\&. If that certificate is not self-signed, then you need a certificate for its signer, and so on, up to a self-signed root CA certificate\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1030
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1031
The \f3cacerts\fR keystore file ships with several VeriSign root CA certificates, so you probably will not need to import a VeriSign certificate as a trusted certificate in your keystore\&. But if you request a signed certificate from a different CA, and a certificate authenticating that CA\&'s public key was not added to \f3cacerts\fR, then you must import a certificate from the CA as a trusted certificate\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1032
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1033
A certificate from a CA is usually either self-signed or signed by another CA, in which case you need a certificate that authenticates that CA\&'s public key\&. Suppose company ABC, Inc\&., is a CA, and you obtain a file named A\f3BCCA\&.cer\fR that is supposed to be a self-signed certificate from ABC, that authenticates that CA\&'s public key\&. Be careful to ensure the certificate is valid before you import it as a trusted certificate\&. View it first with the \f3keytool -printcert\fR command or the \f3keytool -importcert\fR command without the \f3-noprompt\fR option, and make sure that the displayed certificate fingerprints match the expected ones\&. You can call the person who sent the certificate, and compare the fingerprints that you see with the ones that they show or that a secure public key repository shows\&. Only when the fingerprints are equal is it guaranteed that the certificate was not replaced in transit with somebody else\&'s (for example, an attacker\&'s) certificate\&. If such an attack takes place, and you did not check the certificate before you imported it, then you would be trusting anything the attacker has signed\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1034
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1035
If you trust that the certificate is valid, then you can add it to your keystore with the following command:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1036
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1037
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1038
\f3keytool \-importcert \-alias abc \-file ABCCA\&.cer\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1039
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1040
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1041
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1042
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1043
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1044
This command creates a trusted certificate entry in the keystore, with the data from the file ABCCA\&.cer, and assigns the alias \f3abc\fR to the entry\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1045
.SS IMPORT\ THE\ CERTIFICATE\ REPLY\ FROM\ THE\ CA    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1046
After you import a certificate that authenticates the public key of the CA you submitted your certificate signing request to (or there is already such a certificate in the cacerts file), you can import the certificate reply and replace your self-signed certificate with a certificate chain\&. This chain is the one returned by the CA in response to your request (when the CA reply is a chain), or one constructed (when the CA reply is a single certificate) using the certificate reply and trusted certificates that are already available in the keystore where you import the reply or in the \f3cacerts\fR keystore file\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1047
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1048
For example, if you sent your certificate signing request to VeriSign, then you can import the reply with the following, which assumes the returned certificate is named VSMarkJ\&.cer:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1049
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1050
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1051
\f3keytool \-importcert \-trustcacerts \-file VSMarkJ\&.cer\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1052
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1053
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1054
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1055
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1056
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1057
.SS EXPORT\ A\ CERTIFICATE\ THAT\ AUTHENTICATES\ THE\ PUBLIC\ KEY    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1058
If you used the \f3jarsigner\fR command to sign a Java Archive (JAR) file, then clients that want to use the file will want to authenticate your signature\&. One way the clients can authenticate you is by first importing your public key certificate into their keystore as a trusted entry\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1059
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1060
You can export the certificate and supply it to your clients\&. As an example, you can copy your certificate to a file named MJ\&.cer with the following command that assumes the entry has an alias of \f3mykey\fR:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1061
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1062
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1063
\f3keytool \-exportcert \-alias mykey \-file MJ\&.cer\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1064
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1065
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1066
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1067
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1068
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1069
With the certificate and the signed JAR file, a client can use the \f3jarsigner\fR command to authenticate your signature\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1070
.SS IMPORT\ KEYSTORE    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1071
The command \f3importkeystore\fR is used to import an entire keystore into another keystore, which means all entries from the source keystore, including keys and certificates, are all imported to the destination keystore within a single command\&. You can use this command to import entries from a different type of keystore\&. During the import, all new entries in the destination keystore will have the same alias names and protection passwords (for secret keys and private keys)\&. If the \f3keytool\fR command cannot recover the private keys or secret keys from the source keystore, then it prompts you for a password\&. If it detects alias duplication, then it asks you for a new alias, and you can specify a new alias or simply allow the \f3keytool\fR command to overwrite the existing one\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1072
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1073
For example, to import entries from a typical JKS type keystore key\&.jks into a PKCS #11 type hardware-based keystore, use the command:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1074
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1075
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1076
\f3keytool \-importkeystore\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1077
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1078
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1079
\f3    \-srckeystore key\&.jks \-destkeystore NONE\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1080
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1081
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1082
\f3    \-srcstoretype JKS \-deststoretype PKCS11\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1083
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1084
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1085
\f3    \-srcstorepass <src keystore password>\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1086
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1087
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1088
\f3    \-deststorepass <destination keystore pwd>\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1089
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1090
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1091
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1092
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1093
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1094
The \f3importkeystore\fR command can also be used to import a single entry from a source keystore to a destination keystore\&. In this case, besides the options you see in the previous example, you need to specify the alias you want to import\&. With the \f3-srcalias\fR option specified, you can also specify the destination alias name in the command line, as well as protection password for a secret/private key and the destination protection password you want\&. The following command demonstrates this:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1095
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1096
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1097
\f3keytool \-importkeystore\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1098
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1099
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1100
\f3    \-srckeystore key\&.jks \-destkeystore NONE\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1101
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1102
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1103
\f3    \-srcstoretype JKS \-deststoretype PKCS11\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1104
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1105
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1106
\f3    \-srcstorepass <src keystore password>\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1107
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1108
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1109
\f3    \-deststorepass <destination keystore pwd>\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1110
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1111
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1112
\f3    \-srcalias myprivatekey \-destalias myoldprivatekey\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1113
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1114
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1115
\f3    \-srckeypass <source entry password>\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1116
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1117
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1118
\f3    \-destkeypass <destination entry password>\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1119
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1120
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1121
\f3    \-noprompt\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1122
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1123
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1124
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1125
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1126
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1127
.SS GENERATE\ CERTIFICATES\ FOR\ AN\ SSL\ SERVER    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1128
The following are \f3keytool\fR commands to generate key pairs and certificates for three entities: Root CA (\f3root\fR), Intermediate CA (\f3ca\fR), and SSL server (\f3server\fR)\&. Ensure that you store all the certificates in the same keystore\&. In these examples, RSA is the recommended the key algorithm\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1129
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1130
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1131
\f3keytool \-genkeypair \-keystore root\&.jks \-alias root \-ext bc:c\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1132
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1133
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1134
\f3keytool \-genkeypair \-keystore ca\&.jks \-alias ca \-ext bc:c\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1135
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1136
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1137
\f3keytool \-genkeypair \-keystore server\&.jks \-alias server\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1138
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1139
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1140
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1141
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1142
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1143
\f3keytool \-keystore root\&.jks \-alias root \-exportcert \-rfc > root\&.pem\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1144
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1145
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1146
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1147
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1148
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1149
\f3keytool \-storepass <storepass> \-keystore ca\&.jks \-certreq \-alias ca |\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1150
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1151
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1152
\f3    keytool \-storepass <storepass> \-keystore root\&.jks\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1153
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1154
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1155
\f3    \-gencert \-alias root \-ext BC=0 \-rfc > ca\&.pem\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1156
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1157
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1158
\f3keytool \-keystore ca\&.jks \-importcert \-alias ca \-file ca\&.pem\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1159
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1160
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1161
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1162
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1163
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1164
\f3keytool \-storepass <storepass> \-keystore server\&.jks \-certreq \-alias server |\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1165
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1166
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1167
\f3    keytool \-storepass <storepass> \-keystore ca\&.jks \-gencert \-alias ca\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1168
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1169
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1170
\f3    \-ext ku:c=dig,kE \-rfc > server\&.pem\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1171
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1172
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1173
\f3cat root\&.pem ca\&.pem server\&.pem |\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1174
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1175
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1176
\f3    keytool \-keystore server\&.jks \-importcert \-alias server\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1177
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1178
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1179
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1180
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1181
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1182
.SH TERMS    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1183
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1184
Keystore
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1185
A keystore is a storage facility for cryptographic keys and certificates\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1186
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1187
Keystore entries
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1188
Keystores can have different types of entries\&. The two most applicable entry types for the \f3keytool\fR command include the following:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1189
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1190
\fIKey entries\fR: Each entry holds very sensitive cryptographic key information, which is stored in a protected format to prevent unauthorized access\&. Typically, a key stored in this type of entry is a secret key, or a private key accompanied by the certificate chain for the corresponding public key\&. See Certificate Chains\&. The \f3keytool\fR command can handle both types of entries, while the \f3jarsigner\fR tool only handles the latter type of entry, that is private keys and their associated certificate chains\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1191
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1192
\fITrusted certificate entries\fR: Each entry contains a single public key certificate that belongs to another party\&. The entry is called a trusted certificate because the keystore owner trusts that the public key in the certificate belongs to the identity identified by the subject (owner) of the certificate\&. The issuer of the certificate vouches for this, by signing the certificate\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1193
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1194
KeyStore aliases
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1195
All keystore entries (key and trusted certificate entries) are accessed by way of unique aliases\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1196
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1197
An alias is specified when you add an entity to the keystore with the \f3-genseckey\fR command to generate a secret key, the \f3-genkeypair\fR command to generate a key pair (public and private key), or the \f3-importcert\fR command to add a certificate or certificate chain to the list of trusted certificates\&. Subsequent \f3keytool\fR commands must use this same alias to refer to the entity\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1198
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1199
For example, you can use the alias \f3duke\fR to generate a new public/private key pair and wrap the public key into a self-signed certificate with the following command\&. See Certificate Chains\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1200
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1201
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1202
\f3keytool \-genkeypair \-alias duke \-keypass dukekeypasswd\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1203
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1204
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1205
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1206
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1207
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1208
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1209
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1210
This example specifies an initial password of \f3dukekeypasswd\fR required by subsequent commands to access the private key associated with the alias \f3duke\fR\&. If you later want to change Duke\&'s private key password, use a command such as the following:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1211
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1212
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1213
\f3keytool \-keypasswd \-alias duke \-keypass dukekeypasswd \-new newpass\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1214
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1215
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1216
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1217
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1218
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1219
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1220
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1221
This changes the password from \f3dukekeypasswd\fR to \f3newpass\fR\&. A password should not be specified on a command line or in a script unless it is for testing purposes, or you are on a secure system\&. If you do not specify a required password option on a command line, then you are prompted for it\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1222
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1223
KeyStore implementation
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1224
The \f3KeyStore\fR class provided in the \f3java\&.security\fR package supplies well-defined interfaces to access and modify the information in a keystore\&. It is possible for there to be multiple different concrete implementations, where each implementation is that for a particular type of keystore\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1225
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1226
Currently, two command-line tools (\f3keytool\fR and \f3jarsigner\fR) and a GUI-based tool named Policy Tool make use of keystore implementations\&. Because the \f3KeyStore\fR class is \f3public\fR, users can write additional security applications that use it\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1227
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1228
There is a built-in default implementation, provided by Oracle\&. It implements the keystore as a file with a proprietary keystore type (format) named JKS\&. It protects each private key with its individual password, and also protects the integrity of the entire keystore with a (possibly different) password\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1229
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1230
Keystore implementations are provider-based\&. More specifically, the application interfaces supplied by \f3KeyStore\fR are implemented in terms of a Service Provider Interface (SPI)\&. That is, there is a corresponding abstract \f3KeystoreSpi\fR class, also in the \f3java\&.security package\fR, which defines the Service Provider Interface methods that providers must implement\&. The term \fIprovider\fR refers to a package or a set of packages that supply a concrete implementation of a subset of services that can be accessed by the Java Security API\&. To provide a keystore implementation, clients must implement a provider and supply a \f3KeystoreSpi\fR subclass implementation, as described in How to Implement a Provider in the Java Cryptography Architecture at http://docs\&.oracle\&.com/javase/8/docs/technotes/guides/security/crypto/HowToImplAProvider\&.html
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1231
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1232
Applications can choose different types of keystore implementations from different providers, using the \f3getInstance\fR factory method supplied in the \f3KeyStore\fR class\&. A keystore type defines the storage and data format of the keystore information, and the algorithms used to protect private/secret keys in the keystore and the integrity of the keystore\&. Keystore implementations of different types are not compatible\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1233
47224
e81f9ee4df7f 8148371: Remove policytool
weijun
parents: 47216
diff changeset
  1234
The \f3keytool\fR command works on any file-based keystore implementation\&. It treats the keystore location that is passed to it at the command line as a file name and converts it to a \f3FileInputStream\fR, from which it loads the keystore information\&.)The \f3jarsigner\fR command can read a keystore from any location that can be specified with a URL\&.
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1235
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1236
For \f3keytool\fR and \f3jarsigner\fR, you can specify a keystore type at the command line, with the \f3-storetype\fR option\&. For Policy Tool, you can specify a keystore type with the \fIKeystore\fR menu\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1237
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1238
If you do not explicitly specify a keystore type, then the tools choose a keystore implementation based on the value of the \f3keystore\&.type\fR property specified in the security properties file\&. The security properties file is called \f3java\&.security\fR, and resides in the security properties directory, \f3java\&.home\elib\esecurity\fR on Windows and \f3java\&.home/lib/security\fR on Oracle Solaris, where \f3java\&.home\fR is the runtime environment directory\&. The \f3jre\fR directory in the SDK or the top-level directory of the Java Runtime Environment (JRE)\&.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1239
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1240
Each tool gets the \f3keystore\&.type\fR value and then examines all the currently installed providers until it finds one that implements a keystores of that type\&. It then uses the keystore implementation from that provider\&.The \f3KeyStore\fR class defines a static method named \f3getDefaultType\fR that lets applications and applets retrieve the value of the \f3keystore\&.type\fR property\&. The following line of code creates an instance of the default keystore type as specified in the \f3keystore\&.type\fR property:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1241
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1242
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1243
\f3KeyStore keyStore = KeyStore\&.getInstance(KeyStore\&.getDefaultType());\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1244
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1245
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1246
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1247
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1248
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1249
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1250
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1251
The default keystore type is \f3jks\fR, which is the proprietary type of the keystore implementation provided by Oracle\&. This is specified by the following line in the security properties file:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1252
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1253
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1254
\f3keystore\&.type=jks\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1255
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1256
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1257
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1258
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1259
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1260
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1261
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1262
To have the tools utilize a keystore implementation other than the default, you can change that line to specify a different keystore type\&. For example, if you have a provider package that supplies a keystore implementation for a keystore type called \f3pkcs12\fR, then change the line to the following:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1263
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1264
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1265
\f3keystore\&.type=pkcs12\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1266
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1267
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1268
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1269
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1270
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1271
9573
c02ff5a7c67b 7043684: Update man pages for JDK 7 tools
bpatel
parents: 5865
diff changeset
  1272
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1273
\fINote:\fR Case does not matter in keystore type designations\&. For example, JKS would be considered the same as jks\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1274
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1275
Certificate
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1276
A certificate (or public-key certificate) is a digitally signed statement from one entity (the issuer), saying that the public key and some other information of another entity (the subject) has some specific value\&. The following terms are related to certificates:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1277
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1278
\fIPublic Keys\fR: These are numbers associated with a particular entity, and are intended to be known to everyone who needs to have trusted interactions with that entity\&. Public keys are used to verify signatures\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1279
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1280
\fIDigitally Signed\fR: If some data is digitally signed, then it is stored with the identity of an entity and a signature that proves that entity knows about the data\&. The data is rendered unforgeable by signing with the entity\&'s private key\&.
9573
c02ff5a7c67b 7043684: Update man pages for JDK 7 tools
bpatel
parents: 5865
diff changeset
  1281
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1282
\fIIdentity\fR: A known way of addressing an entity\&. In some systems, the identity is the public key, and in others it can be anything from an Oracle Solaris UID to an email address to an X\&.509 distinguished name\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1283
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1284
\fISignature\fR: A signature is computed over some data using the private key of an entity\&. The signer, which in the case of a certificate is also known as the issuer\&.
9573
c02ff5a7c67b 7043684: Update man pages for JDK 7 tools
bpatel
parents: 5865
diff changeset
  1285
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1286
\fIPrivate Keys\fR: These are numbers, each of which is supposed to be known only to the particular entity whose private key it is (that is, it is supposed to be kept secret)\&. Private and public keys exist in pairs in all public key cryptography systems (also referred to as public key crypto systems)\&. In a typical public key crypto system, such as DSA, a private key corresponds to exactly one public key\&. Private keys are used to compute signatures\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1287
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1288
\fIEntity\fR: An entity is a person, organization, program, computer, business, bank, or something else you are trusting to some degree\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1289
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1290
Public key cryptography requires access to users\&' public keys\&. In a large-scale networked environment, it is impossible to guarantee that prior relationships between communicating entities were established or that a trusted repository exists with all used public keys\&. Certificates were invented as a solution to this public key distribution problem\&. Now a Certification Authority (CA) can act as a trusted third party\&. CAs are entities such as businesses that are trusted to sign (issue) certificates for other entities\&. It is assumed that CAs only create valid and reliable certificates because they are bound by legal agreements\&. There are many public Certification Authorities, such as VeriSign, Thawte, Entrust, and so on\&.
2692
345bc8d65b19 6837214: Update JDK7 man pages
tbell
parents: 2
diff changeset
  1291
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1292
You can also run your own Certification Authority using products such as Microsoft Certificate Server or the Entrust CA product for your organization\&. With the \f3keytool\fR command, it is possible to display, import, and export certificates\&. It is also possible to generate self-signed certificates\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1293
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1294
The \f3keytool\fR command currently handles X\&.509 certificates\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1295
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1296
X\&.509 Certificates
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1297
The X\&.509 standard defines what information can go into a certificate and describes how to write it down (the data format)\&. All the data in a certificate is encoded with two related standards called ASN\&.1/DER\&. Abstract Syntax Notation 1 describes data\&. The Definite Encoding Rules describe a single way to store and transfer that data\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1298
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1299
All X\&.509 certificates have the following data, in addition to the signature:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1300
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1301
\fIVersion\fR: This identifies which version of the X\&.509 standard applies to this certificate, which affects what information can be specified in it\&. Thus far, three versions are defined\&. The \f3keytool\fR command can import and export v1, v2, and v3 certificates\&. It generates v3 certificates\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1302
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1303
X\&.509 Version 1 has been available since 1988, is widely deployed, and is the most generic\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1304
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1305
X\&.509 Version 2 introduced the concept of subject and issuer unique identifiers to handle the possibility of reuse of subject or issuer names over time\&. Most certificate profile documents strongly recommend that names not be reused and that certificates should not make use of unique identifiers\&. Version 2 certificates are not widely used\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1306
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1307
X\&.509 Version 3 is the most recent (1996) and supports the notion of extensions where anyone can define an extension and include it in the certificate\&. Some common extensions are: KeyUsage (limits the use of the keys to particular purposes such as \f3signing-only\fR) and AlternativeNames (allows other identities to also be associated with this public key, for example\&. DNS names, email addresses, IP addresses)\&. Extensions can be marked critical to indicate that the extension should be checked and enforced or used\&. For example, if a certificate has the KeyUsage extension marked critical and set to \f3keyCertSign\fR, then when this certificate is presented during SSL communication, it should be rejected because the certificate extension indicates that the associated private key should only be used for signing certificates and not for SSL use\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1308
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1309
\fISerial number\fR: The entity that created the certificate is responsible for assigning it a serial number to distinguish it from other certificates it issues\&. This information is used in numerous ways\&. For example, when a certificate is revoked its serial number is placed in a Certificate Revocation List (CRL)\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1310
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1311
\fISignature algorithm identifier\fR: This identifies the algorithm used by the CA to sign the certificate\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1312
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1313
\fIIssuer name\fR: The X\&.500 Distinguished Name of the entity that signed the certificate\&. See X\&.500 Distinguished Names\&. This is typically a CA\&. Using this certificate implies trusting the entity that signed this certificate\&. In some cases, such as root or top-level CA certificates, the issuer signs its own certificate\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1314
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1315
\fIValidity period\fR: Each certificate is valid only for a limited amount of time\&. This period is described by a start date and time and an end date and time, and can be as short as a few seconds or almost as long as a century\&. The validity period chosen depends on a number of factors, such as the strength of the private key used to sign the certificate, or the amount one is willing to pay for a certificate\&. This is the expected period that entities can rely on the public value, when the associated private key has not been compromised\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1316
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1317
\fISubject name\fR: The name of the entity whose public key the certificate identifies\&. This name uses the X\&.500 standard, so it is intended to be unique across the Internet\&. This is the X\&.500 Distinguished Name (DN) of the entity\&. See X\&.500 Distinguished Names\&. For example,
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1318
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1319
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1320
\f3CN=Java Duke, OU=Java Software Division, O=Oracle Corporation, C=US\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1321
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1322
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1323
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1324
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1325
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1326
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1327
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1328
These refer to the subject\&'s common name (CN), organizational unit (OU), organization (O), and country (C)\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1329
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1330
\fISubject public key information\fR: This is the public key of the entity being named with an algorithm identifier that specifies which public key crypto system this key belongs to and any associated key parameters\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1331
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1332
Certificate Chains
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1333
The \f3keytool\fR command can create and manage keystore key entries that each contain a private key and an associated certificate chain\&. The first certificate in the chain contains the public key that corresponds to the private key\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1334
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1335
When keys are first generated, the chain starts off containing a single element, a self-signed certificate\&. See \f3-genkeypair\fR in Commands\&. A self-signed certificate is one for which the issuer (signer) is the same as the subject\&. The subject is the entity whose public key is being authenticated by the certificate\&. Whenever the \f3-genkeypair\fR command is called to generate a new public/private key pair, it also wraps the public key into a self-signed certificate\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1336
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1337
Later, after a Certificate Signing Request (CSR) was generated with the \f3-certreq\fR command and sent to a Certification Authority (CA), the response from the CA is imported with \f3-importcert\fR, and the self-signed certificate is replaced by a chain of certificates\&. See the \f3-certreq\fR and \f3-importcert\fR options in Commands\&. At the bottom of the chain is the certificate (reply) issued by the CA authenticating the subject\&'s public key\&. The next certificate in the chain is one that authenticates the CA\&'s public key\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1338
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1339
In many cases, this is a self-signed certificate, which is a certificate from the CA authenticating its own public key, and the last certificate in the chain\&. In other cases, the CA might return a chain of certificates\&. In this case, the bottom certificate in the chain is the same (a certificate signed by the CA, authenticating the public key of the key entry), but the second certificate in the chain is a certificate signed by a different CA that authenticates the public key of the CA you sent the CSR to\&. The next certificate in the chain is a certificate that authenticates the second CA\&'s key, and so on, until a self-signed root certificate is reached\&. Each certificate in the chain (after the first) authenticates the public key of the signer of the previous certificate in the chain\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1340
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1341
Many CAs only return the issued certificate, with no supporting chain, especially when there is a flat hierarchy (no intermediates CAs)\&. In this case, the certificate chain must be established from trusted certificate information already stored in the keystore\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1342
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1343
A different reply format (defined by the PKCS #7 standard) includes the supporting certificate chain in addition to the issued certificate\&. Both reply formats can be handled by the \f3keytool\fR command\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1344
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1345
The top-level (root) CA certificate is self-signed\&. However, the trust into the root\&'s public key does not come from the root certificate itself, but from other sources such as a newspaper\&. This is because anybody could generate a self-signed certificate with the distinguished name of, for example, the VeriSign root CA\&. The root CA public key is widely known\&. The only reason it is stored in a certificate is because this is the format understood by most tools, so the certificate in this case is only used as a vehicle to transport the root CA\&'s public key\&. Before you add the root CA certificate to your keystore, you should view it with the \f3-printcert\fR option and compare the displayed fingerprint with the well-known fingerprint obtained from a newspaper, the root CA\&'s Web page, and so on\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1346
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1347
The cacerts Certificates File
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1348
A certificates file named \f3cacerts\fR resides in the security properties directory, \f3java\&.home\elib\esecurity\fR on Windows and \f3java\&.home/lib/security\fR on Oracle Solaris, where \f3java\&.home\fR is the runtime environment\&'s directory, which would be the \f3jre\fR directory in the SDK or the top-level directory of the JRE\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1349
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1350
The \f3cacerts\fR file represents a system-wide keystore with CA certificates\&. System administrators can configure and manage that file with the \f3keytool\fR command by specifying \f3jks\fR as the keystore type\&. The \f3cacerts\fR keystore file ships with a default set of root CA certificates\&. You can list the default certificates with the following command:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1351
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1352
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1353
\f3keytool \-list \-keystore java\&.home/lib/security/cacerts\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1354
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1355
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1356
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1357
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1358
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1359
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1360
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1361
The initial password of the \f3cacerts\fR keystore file is \f3changeit\fR\&. System administrators should change that password and the default access permission of that file upon installing the SDK\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1362
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1363
\fINote:\fR It is important to verify your \f3cacerts\fR file\&. Because you trust the CAs in the \f3cacerts\fR file as entities for signing and issuing certificates to other entities, you must manage the \f3cacerts\fR file carefully\&. The \f3cacerts\fR file should contain only certificates of the CAs you trust\&. It is your responsibility to verify the trusted root CA certificates bundled in the \f3cacerts\fR file and make your own trust decisions\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1364
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1365
To remove an untrusted CA certificate from the \f3cacerts\fR file, use the \f3delete\fR option of the \f3keytool\fR command\&. You can find the \f3cacerts\fR file in the JRE installation directory\&. Contact your system administrator if you do not have permission to edit this file
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1366
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1367
Internet RFC 1421 Certificate Encoding Standard
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1368
Certificates are often stored using the printable encoding format defined by the Internet RFC 1421 standard, instead of their binary encoding\&. This certificate format, also known as Base64 encoding, makes it easy to export certificates to other applications by email or through some other mechanism\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1369
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1370
Certificates read by the \f3-importcert\fR and \f3-printcert\fR commands can be in either this format or binary encoded\&. The \f3-exportcert\fR command by default outputs a certificate in binary encoding, but will instead output a certificate in the printable encoding format, when the \f3-rfc\fR option is specified\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1371
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1372
The \f3-list\fR command by default prints the SHA1 fingerprint of a certificate\&. If the \f3-v\fR option is specified, then the certificate is printed in human-readable format\&. If the \f3-rfc\fR option is specified, then the certificate is output in the printable encoding format\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1373
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1374
In its printable encoding format, the encoded certificate is bounded at the beginning and end by the following text:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1375
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1376
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1377
\f3\-\-\-\-\-BEGIN CERTIFICATE\-\-\-\-\-\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1378
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1379
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1380
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1381
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1382
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1383
\f3encoded certificate goes here\&. \fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1384
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1385
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1386
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1387
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1388
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1389
\f3\-\-\-\-\-END CERTIFICATE\-\-\-\-\-\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1390
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1391
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1392
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1393
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1394
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1395
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1396
.TP     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1397
X\&.500 Distinguished Names
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1398
X\&.500 Distinguished Names are used to identify entities, such as those that are named by the \f3subject\fR and \f3issuer\fR (signer) fields of X\&.509 certificates\&. The \f3keytool\fR command supports the following subparts:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1399
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1400
\fIcommonName\fR: The common name of a person such as Susan Jones\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1401
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1402
\fIorganizationUnit\fR: The small organization (such as department or division) name\&. For example, Purchasing\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1403
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1404
\fIlocalityName\fR: The locality (city) name, for example, Palo Alto\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1405
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1406
\fIstateName\fR: State or province name, for example, California\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1407
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1408
\fIcountry\fR: Two-letter country code, for example, CH\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1409
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1410
When you supply a distinguished name string as the value of a \f3-dname\fR option, such as for the \f3-genkeypair\fR command, the string must be in the following format:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1411
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1412
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1413
\f3CN=cName, OU=orgUnit, O=org, L=city, S=state, C=countryCode\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1414
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1415
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1416
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1417
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1418
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1419
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1420
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1421
All the italicized items represent actual values and the previous keywords are abbreviations for the following:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1422
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1423
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1424
\f3CN=commonName\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1425
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1426
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1427
\f3OU=organizationUnit\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1428
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1429
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1430
\f3O=organizationName\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1431
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1432
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1433
\f3L=localityName\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1434
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1435
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1436
\f3S=stateName\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1437
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1438
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1439
\f3C=country\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1440
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1441
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1442
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1443
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1444
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1445
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1446
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1447
A sample distinguished name string is:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1448
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1449
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1450
\f3CN=Mark Smith, OU=Java, O=Oracle, L=Cupertino, S=California, C=US\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1451
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1452
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1453
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1454
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1455
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1456
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1457
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1458
A sample command using such a string is:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1459
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1460
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1461
\f3keytool \-genkeypair \-dname "CN=Mark Smith, OU=Java, O=Oracle, L=Cupertino,\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1462
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1463
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1464
\f3S=California, C=US" \-alias mark\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1465
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1466
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1467
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1468
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1469
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1470
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1471
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1472
Case does not matter for the keyword abbreviations\&. For example, CN, cn, and Cn are all treated the same\&.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1473
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1474
Order matters; each subcomponent must appear in the designated order\&. However, it is not necessary to have all the subcomponents\&. You can use a subset, for example:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1475
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1476
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1477
\f3CN=Steve Meier, OU=Java, O=Oracle, C=US\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1478
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1479
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1480
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1481
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1482
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1483
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1484
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1485
If a distinguished name string value contains a comma, then the comma must be escaped by a backslash (\e) character when you specify the string on a command line, as in:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1486
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1487
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1488
\f3cn=Peter Schuster, ou=Java\e, Product Development, o=Oracle, c=US\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1489
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1490
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1491
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1492
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1493
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1494
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1495
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1496
It is never necessary to specify a distinguished name string on a command line\&. When the distinguished name is needed for a command, but not supplied on the command line, the user is prompted for each of the subcomponents\&. In this case, a comma does not need to be escaped by a backslash (\e)\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1497
.SH WARNINGS    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1498
.SS IMPORTING\ TRUSTED\ CERTIFICATES\ WARNING    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1499
\fIImportant\fR: Be sure to check a certificate very carefully before importing it as a trusted certificate\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1500
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1501
Windows Example:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1502
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1503
View the certificate first with the \f3-printcert\fR command or the \f3-importcert\fR command without the \f3-noprompt\fR option\&. Ensure that the displayed certificate fingerprints match the expected ones\&. For example, suppose sends or emails you a certificate that you put it in a file named \f3\etmp\ecert\fR\&. Before you consider adding the certificate to your list of trusted certificates, you can execute a \f3-printcert\fR command to view its fingerprints, as follows:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1504
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1505
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1506
\f3  keytool \-printcert \-file \etmp\ecert\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1507
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1508
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1509
\f3    Owner: CN=ll, OU=ll, O=ll, L=ll, S=ll, C=ll\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1510
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1511
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1512
\f3    Issuer: CN=ll, OU=ll, O=ll, L=ll, S=ll, C=ll\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1513
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1514
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1515
\f3    Serial Number: 59092b34\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1516
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1517
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1518
\f3    Valid from: Thu Sep 25 18:01:13 PDT 1997 until: Wed Dec 24 17:01:13 PST 1997\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1519
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1520
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1521
\f3    Certificate Fingerprints:\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1522
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1523
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1524
\f3         MD5:  11:81:AD:92:C8:E5:0E:A2:01:2E:D4:7A:D7:5F:07:6F\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1525
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1526
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1527
\f3         SHA1: 20:B6:17:FA:EF:E5:55:8A:D0:71:1F:E8:D6:9D:C0:37:13:0E:5E:FE\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1528
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1529
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1530
\f3         SHA256: 90:7B:70:0A:EA:DC:16:79:92:99:41:FF:8A:FE:EB:90:\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1531
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1532
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1533
\f3                 17:75:E0:90:B2:24:4D:3A:2A:16:A6:E4:11:0F:67:A4\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1534
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1535
.sp     
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1536
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1537
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1538
Oracle Solaris Example:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
  1539
21743
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1540
View the certificate first with the \f3-printcert\fR command or the \f3-importcert\fR command without the \f3-noprompt\fR option\&. Ensure that the displayed certificate fingerprints match the expected ones\&. For example, suppose someone sends or emails you a certificate that you put it in a file named \f3/tmp/cert\fR\&. Before you consider adding the certificate to your list of trusted certificates, you can execute a \f3-printcert\fR command to view its fingerprints, as follows:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1541
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1542
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1543
\f3  keytool \-printcert \-file /tmp/cert\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1544
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1545
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1546
\f3    Owner: CN=ll, OU=ll, O=ll, L=ll, S=ll, C=ll\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1547
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1548
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1549
\f3    Issuer: CN=ll, OU=ll, O=ll, L=ll, S=ll, C=ll\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1550
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1551
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1552
\f3    Serial Number: 59092b34\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1553
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1554
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1555
\f3    Valid from: Thu Sep 25 18:01:13 PDT 1997 until: Wed Dec 24 17:01:13 PST 1997\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1556
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1557
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1558
\f3    Certificate Fingerprints:\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1559
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1560
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1561
\f3         MD5:  11:81:AD:92:C8:E5:0E:A2:01:2E:D4:7A:D7:5F:07:6F\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1562
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1563
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1564
\f3         SHA1: 20:B6:17:FA:EF:E5:55:8A:D0:71:1F:E8:D6:9D:C0:37:13:0E:5E:FE\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1565
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1566
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1567
\f3         SHA256: 90:7B:70:0A:EA:DC:16:79:92:99:41:FF:8A:FE:EB:90:\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1568
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1569
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1570
\f3                 17:75:E0:90:B2:24:4D:3A:2A:16:A6:E4:11:0F:67:A4\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1571
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1572
.nf     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1573
\f3\fP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1574
.fi     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1575
.sp     
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1576
Then call or otherwise contact the person who sent the certificate and compare the fingerprints that you see with the ones that they show\&. Only when the fingerprints are equal is it guaranteed that the certificate was not replaced in transit with somebody else\&'s certificate such as an attacker\&'s certificate\&. If such an attack took place, and you did not check the certificate before you imported it, then you would be trusting anything the attacker signed, for example, a JAR file with malicious class files inside\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1577
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1578
\fINote:\fR It is not required that you execute a \f3-printcert\fR command before importing a certificate\&. This is because before you add a certificate to the list of trusted certificates in the keystore, the \f3-importcert\fR command prints out the certificate information and prompts you to verify it\&. You can then stop the import operation\&. However, you can do this only when you call the \f3-importcert\fR command without the \f3-noprompt\fR option\&. If the \f3-noprompt\fR option is specified, then there is no interaction with the user\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1579
.SS PASSWORDS\ WARNING    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1580
Most commands that operate on a keystore require the store password\&. Some commands require a private/secret key password\&. Passwords can be specified on the command line in the \f3-storepass\fR and \f3-keypass\fR options\&. However, a password should not be specified on a command line or in a script unless it is for testing, or you are on a secure system\&. When you do not specify a required password option on a command line, you are prompted for it\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1581
.SS CERTIFICATE\ CONFORMANCE\ WARNING    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1582
The Internet standard RFC 5280 has defined a profile on conforming X\&.509 certificates, which includes what values and value combinations are valid for certificate fields and extensions\&. See the standard at http://tools\&.ietf\&.org/rfc/rfc5280\&.txt
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1583
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1584
The \f3keytool\fR command does not enforce all of these rules so it can generate certificates that do not conform to the standard\&. Certificates that do not conform to the standard might be rejected by JRE or other applications\&. Users should ensure that they provide the correct options for \f3-dname\fR, \f3-ext\fR, and so on\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1585
.SH NOTES    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1586
.SS IMPORT\ A\ NEW\ TRUSTED\ CERTIFICATE    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1587
Before you add the certificate to the keystore, the \f3keytool\fR command verifies it by attempting to construct a chain of trust from that certificate to a self-signed certificate (belonging to a root CA), using trusted certificates that are already available in the keystore\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1588
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1589
If the \f3-trustcacerts\fR option was specified, then additional certificates are considered for the chain of trust, namely the certificates in a file named \f3cacerts\fR\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1590
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1591
If the \f3keytool\fR command fails to establish a trust path from the certificate to be imported up to a self-signed certificate (either from the keystore or the \f3cacerts\fR file), then the certificate information is printed, and the user is prompted to verify it by comparing the displayed certificate fingerprints with the fingerprints obtained from some other (trusted) source of information, which might be the certificate owner\&. Be very careful to ensure the certificate is valid before importing it as a trusted certificate\&. See Importing Trusted Certificates Warning\&. The user then has the option of stopping the import operation\&. If the \f3-noprompt\fR option is specified, then there is no interaction with the user\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1592
.SS IMPORT\ A\ CERTIFICATE\ REPLY    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1593
When you import a certificate reply, the certificate reply is validated with trusted certificates from the keystore, and optionally, the certificates configured in the \f3cacerts\fR keystore file when the \f3-trustcacert\fR\f3s\fR option is specified\&. See The cacerts Certificates File\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1594
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1595
The methods of determining whether the certificate reply is trusted are as follows:
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1596
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1597
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1598
If the reply is a single X\&.509 certificate, then the \f3keytool\fR command attempts to establish a trust chain, starting at the certificate reply and ending at a self-signed certificate (belonging to a root CA)\&. The certificate reply and the hierarchy of certificates is used to authenticate the certificate reply from the new certificate chain of aliases\&. If a trust chain cannot be established, then the certificate reply is not imported\&. In this case, the \f3keytool\fR command does not print the certificate and prompt the user to verify it, because it is very difficult for a user to determine the authenticity of the certificate reply\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1599
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1600
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1601
If the reply is a PKCS #7 formatted certificate chain or a sequence of X\&.509 certificates, then the chain is ordered with the user certificate first followed by zero or more CA certificates\&. If the chain ends with a self-signed root CA certificate and the\f3-trustcacerts\fR option was specified, the \f3keytool\fR command attempts to match it with any of the trusted certificates in the keystore or the \f3cacerts\fR keystore file\&. If the chain does not end with a self-signed root CA certificate and the \f3-trustcacerts\fR option was specified, the \f3keytool\fR command tries to find one from the trusted certificates in the keystore or the \f3cacerts\fR keystore file and add it to the end of the chain\&. If the certificate is not found and the \f3-noprompt\fR option is not specified, the information of the last certificate in the chain is printed, and the user is prompted to verify it\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1602
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1603
If the public key in the certificate reply matches the user\&'s public key already stored with \f3alias\fR, then the old certificate chain is replaced with the new certificate chain in the reply\&. The old chain can only be replaced with a valid \f3keypass\fR, and so the password used to protect the private key of the entry is supplied\&. If no password is provided, and the private key password is different from the keystore password, the user is prompted for it\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1604
.PP
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1605
This command was named \f3-import\fR in earlier releases\&. This old name is still supported in this release\&. The new name, \f3-importcert\fR, is preferred going forward\&.
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1606
.SH SEE\ ALSO    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1607
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1608
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1609
jar(1)
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1610
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1611
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1612
jarsigner(1)
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1613
.TP 0.2i    
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1614
\(bu
3d979da7bdf0 8029043: Update nroff files for JDK 8
rgallard
parents: 9734
diff changeset
  1615
Trail: Security Features in Java SE at http://docs\&.oracle\&.com/javase/tutorial/security/index\&.html
31876
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
  1616
.RE
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
  1617
.br
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
  1618
'pl 8.5i
91b22707521a 8131105: Header Template for nroff man pages *.1 files contains errors
mfang
parents: 21743
diff changeset
  1619
'bp