jdk/src/java.base/share/classes/java/util/jar/JarFile.java
author darcy
Thu, 23 Apr 2015 09:32:35 -0700
changeset 29986 97167d851fc4
parent 27565 729f9700483a
child 30786 fb0d6aaea1dc
permissions -rw-r--r--
8078467: Update core libraries to use diamond with anonymous classes Reviewed-by: mchung, alanb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
19047
08210fe86260 8021408: Fix misc doclint issues in java.util and java.io
darcy
parents: 18822
diff changeset
     2
 * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     4
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
90ce3da70b43 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 4152
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 4152
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    10
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
90ce3da70b43 Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
90ce3da70b43 Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
90ce3da70b43 Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
90ce3da70b43 Initial load
duke
parents:
diff changeset
    16
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
90ce3da70b43 Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    20
 *
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 4152
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 4152
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 4152
diff changeset
    23
 * questions.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    24
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    25
90ce3da70b43 Initial load
duke
parents:
diff changeset
    26
package java.util.jar;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    27
90ce3da70b43 Initial load
duke
parents:
diff changeset
    28
import java.io.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    29
import java.lang.ref.SoftReference;
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
    30
import java.net.URL;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    31
import java.util.*;
17421
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
    32
import java.util.stream.Stream;
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
    33
import java.util.stream.StreamSupport;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    34
import java.util.zip.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    35
import java.security.CodeSigner;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    36
import java.security.cert.Certificate;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    37
import java.security.AccessController;
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
    38
import java.security.CodeSource;
16082
a042f1412a78 8000210: Improve JarFile code quality
weijun
parents: 11274
diff changeset
    39
import sun.misc.IOUtils;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    40
import sun.security.action.GetPropertyAction;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    41
import sun.security.util.ManifestEntryVerifier;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    42
import sun.misc.SharedSecrets;
22578
ff8d54ac7c5c 8031572: jarsigner -verify exits with 0 when a jar file is not properly signed
weijun
parents: 22342
diff changeset
    43
import sun.security.util.SignatureFileVerifier;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    44
90ce3da70b43 Initial load
duke
parents:
diff changeset
    45
/**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    46
 * The <code>JarFile</code> class is used to read the contents of a jar file
90ce3da70b43 Initial load
duke
parents:
diff changeset
    47
 * from any file that can be opened with <code>java.io.RandomAccessFile</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    48
 * It extends the class <code>java.util.zip.ZipFile</code> with support
90ce3da70b43 Initial load
duke
parents:
diff changeset
    49
 * for reading an optional <code>Manifest</code> entry. The
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
 * <code>Manifest</code> can be used to specify meta-information about the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    51
 * jar file and its entries.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    52
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    53
 * <p> Unless otherwise noted, passing a <tt>null</tt> argument to a constructor
90ce3da70b43 Initial load
duke
parents:
diff changeset
    54
 * or method in this class will cause a {@link NullPointerException} to be
90ce3da70b43 Initial load
duke
parents:
diff changeset
    55
 * thrown.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
 *
22316
5668a8abf212 8024659: Clarify JarFile API
weijun
parents: 19409
diff changeset
    57
 * If the verify flag is on when opening a signed jar file, the content of the
5668a8abf212 8024659: Clarify JarFile API
weijun
parents: 19409
diff changeset
    58
 * file is verified against its signature embedded inside the file. Please note
5668a8abf212 8024659: Clarify JarFile API
weijun
parents: 19409
diff changeset
    59
 * that the verification process does not include validating the signer's
5668a8abf212 8024659: Clarify JarFile API
weijun
parents: 19409
diff changeset
    60
 * certificate. A caller should inspect the return value of
5668a8abf212 8024659: Clarify JarFile API
weijun
parents: 19409
diff changeset
    61
 * {@link JarEntry#getCodeSigners()} to further determine if the signature
5668a8abf212 8024659: Clarify JarFile API
weijun
parents: 19409
diff changeset
    62
 * can be trusted.
5668a8abf212 8024659: Clarify JarFile API
weijun
parents: 19409
diff changeset
    63
 *
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    64
 * @author  David Connelly
90ce3da70b43 Initial load
duke
parents:
diff changeset
    65
 * @see     Manifest
90ce3da70b43 Initial load
duke
parents:
diff changeset
    66
 * @see     java.util.zip.ZipFile
90ce3da70b43 Initial load
duke
parents:
diff changeset
    67
 * @see     java.util.jar.JarEntry
90ce3da70b43 Initial load
duke
parents:
diff changeset
    68
 * @since   1.2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    69
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    70
public
90ce3da70b43 Initial load
duke
parents:
diff changeset
    71
class JarFile extends ZipFile {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    72
    private SoftReference<Manifest> manRef;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    73
    private JarEntry manEntry;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    74
    private JarVerifier jv;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    75
    private boolean jvInitialized;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    76
    private boolean verify;
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
    77
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
    78
    // indicates if Class-Path attribute present (only valid if hasCheckedSpecialAttributes true)
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    79
    private boolean hasClassPathAttribute;
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
    80
    // true if manifest checked for special attributes
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
    81
    private volatile boolean hasCheckedSpecialAttributes;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    82
90ce3da70b43 Initial load
duke
parents:
diff changeset
    83
    // Set up JavaUtilJarAccess in SharedSecrets
90ce3da70b43 Initial load
duke
parents:
diff changeset
    84
    static {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    85
        SharedSecrets.setJavaUtilJarAccess(new JavaUtilJarAccessImpl());
90ce3da70b43 Initial load
duke
parents:
diff changeset
    86
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    87
90ce3da70b43 Initial load
duke
parents:
diff changeset
    88
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    89
     * The JAR manifest file name.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    90
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    91
    public static final String MANIFEST_NAME = "META-INF/MANIFEST.MF";
90ce3da70b43 Initial load
duke
parents:
diff changeset
    92
90ce3da70b43 Initial load
duke
parents:
diff changeset
    93
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    94
     * Creates a new <code>JarFile</code> to read from the specified
90ce3da70b43 Initial load
duke
parents:
diff changeset
    95
     * file <code>name</code>. The <code>JarFile</code> will be verified if
90ce3da70b43 Initial load
duke
parents:
diff changeset
    96
     * it is signed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    97
     * @param name the name of the jar file to be opened for reading
90ce3da70b43 Initial load
duke
parents:
diff changeset
    98
     * @throws IOException if an I/O error has occurred
90ce3da70b43 Initial load
duke
parents:
diff changeset
    99
     * @throws SecurityException if access to the file is denied
90ce3da70b43 Initial load
duke
parents:
diff changeset
   100
     *         by the SecurityManager
90ce3da70b43 Initial load
duke
parents:
diff changeset
   101
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   102
    public JarFile(String name) throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   103
        this(new File(name), true, ZipFile.OPEN_READ);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   104
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   105
90ce3da70b43 Initial load
duke
parents:
diff changeset
   106
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   107
     * Creates a new <code>JarFile</code> to read from the specified
90ce3da70b43 Initial load
duke
parents:
diff changeset
   108
     * file <code>name</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   109
     * @param name the name of the jar file to be opened for reading
90ce3da70b43 Initial load
duke
parents:
diff changeset
   110
     * @param verify whether or not to verify the jar file if
90ce3da70b43 Initial load
duke
parents:
diff changeset
   111
     * it is signed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   112
     * @throws IOException if an I/O error has occurred
90ce3da70b43 Initial load
duke
parents:
diff changeset
   113
     * @throws SecurityException if access to the file is denied
90ce3da70b43 Initial load
duke
parents:
diff changeset
   114
     *         by the SecurityManager
90ce3da70b43 Initial load
duke
parents:
diff changeset
   115
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   116
    public JarFile(String name, boolean verify) throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   117
        this(new File(name), verify, ZipFile.OPEN_READ);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   118
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   119
90ce3da70b43 Initial load
duke
parents:
diff changeset
   120
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   121
     * Creates a new <code>JarFile</code> to read from the specified
90ce3da70b43 Initial load
duke
parents:
diff changeset
   122
     * <code>File</code> object. The <code>JarFile</code> will be verified if
90ce3da70b43 Initial load
duke
parents:
diff changeset
   123
     * it is signed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   124
     * @param file the jar file to be opened for reading
90ce3da70b43 Initial load
duke
parents:
diff changeset
   125
     * @throws IOException if an I/O error has occurred
90ce3da70b43 Initial load
duke
parents:
diff changeset
   126
     * @throws SecurityException if access to the file is denied
90ce3da70b43 Initial load
duke
parents:
diff changeset
   127
     *         by the SecurityManager
90ce3da70b43 Initial load
duke
parents:
diff changeset
   128
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   129
    public JarFile(File file) throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   130
        this(file, true, ZipFile.OPEN_READ);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   131
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   132
90ce3da70b43 Initial load
duke
parents:
diff changeset
   133
90ce3da70b43 Initial load
duke
parents:
diff changeset
   134
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   135
     * Creates a new <code>JarFile</code> to read from the specified
90ce3da70b43 Initial load
duke
parents:
diff changeset
   136
     * <code>File</code> object.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   137
     * @param file the jar file to be opened for reading
90ce3da70b43 Initial load
duke
parents:
diff changeset
   138
     * @param verify whether or not to verify the jar file if
90ce3da70b43 Initial load
duke
parents:
diff changeset
   139
     * it is signed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   140
     * @throws IOException if an I/O error has occurred
90ce3da70b43 Initial load
duke
parents:
diff changeset
   141
     * @throws SecurityException if access to the file is denied
90ce3da70b43 Initial load
duke
parents:
diff changeset
   142
     *         by the SecurityManager.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   143
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   144
    public JarFile(File file, boolean verify) throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   145
        this(file, verify, ZipFile.OPEN_READ);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   146
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   147
90ce3da70b43 Initial load
duke
parents:
diff changeset
   148
90ce3da70b43 Initial load
duke
parents:
diff changeset
   149
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   150
     * Creates a new <code>JarFile</code> to read from the specified
90ce3da70b43 Initial load
duke
parents:
diff changeset
   151
     * <code>File</code> object in the specified mode.  The mode argument
90ce3da70b43 Initial load
duke
parents:
diff changeset
   152
     * must be either <tt>OPEN_READ</tt> or <tt>OPEN_READ | OPEN_DELETE</tt>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   153
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   154
     * @param file the jar file to be opened for reading
90ce3da70b43 Initial load
duke
parents:
diff changeset
   155
     * @param verify whether or not to verify the jar file if
90ce3da70b43 Initial load
duke
parents:
diff changeset
   156
     * it is signed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   157
     * @param mode the mode in which the file is to be opened
90ce3da70b43 Initial load
duke
parents:
diff changeset
   158
     * @throws IOException if an I/O error has occurred
90ce3da70b43 Initial load
duke
parents:
diff changeset
   159
     * @throws IllegalArgumentException
90ce3da70b43 Initial load
duke
parents:
diff changeset
   160
     *         if the <tt>mode</tt> argument is invalid
90ce3da70b43 Initial load
duke
parents:
diff changeset
   161
     * @throws SecurityException if access to the file is denied
90ce3da70b43 Initial load
duke
parents:
diff changeset
   162
     *         by the SecurityManager
90ce3da70b43 Initial load
duke
parents:
diff changeset
   163
     * @since 1.3
90ce3da70b43 Initial load
duke
parents:
diff changeset
   164
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   165
    public JarFile(File file, boolean verify, int mode) throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   166
        super(file, mode);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   167
        this.verify = verify;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   168
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   169
90ce3da70b43 Initial load
duke
parents:
diff changeset
   170
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   171
     * Returns the jar file manifest, or <code>null</code> if none.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   172
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   173
     * @return the jar file manifest, or <code>null</code> if none
90ce3da70b43 Initial load
duke
parents:
diff changeset
   174
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   175
     * @throws IllegalStateException
90ce3da70b43 Initial load
duke
parents:
diff changeset
   176
     *         may be thrown if the jar file has been closed
19047
08210fe86260 8021408: Fix misc doclint issues in java.util and java.io
darcy
parents: 18822
diff changeset
   177
     * @throws IOException  if an I/O error has occurred
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   178
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   179
    public Manifest getManifest() throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   180
        return getManifestFromReference();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   181
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   182
90ce3da70b43 Initial load
duke
parents:
diff changeset
   183
    private Manifest getManifestFromReference() throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   184
        Manifest man = manRef != null ? manRef.get() : null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   185
90ce3da70b43 Initial load
duke
parents:
diff changeset
   186
        if (man == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   187
90ce3da70b43 Initial load
duke
parents:
diff changeset
   188
            JarEntry manEntry = getManEntry();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   189
90ce3da70b43 Initial load
duke
parents:
diff changeset
   190
            // If found then load the manifest
90ce3da70b43 Initial load
duke
parents:
diff changeset
   191
            if (manEntry != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   192
                if (verify) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   193
                    byte[] b = getBytes(manEntry);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   194
                    man = new Manifest(new ByteArrayInputStream(b));
90ce3da70b43 Initial load
duke
parents:
diff changeset
   195
                    if (!jvInitialized) {
9365
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   196
                        jv = new JarVerifier(b);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   197
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   198
                } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   199
                    man = new Manifest(super.getInputStream(manEntry));
90ce3da70b43 Initial load
duke
parents:
diff changeset
   200
                }
11274
7e7196757acd 7117249: fix warnings in java.util.jar, .logging, .prefs, .zip
smarks
parents: 9365
diff changeset
   201
                manRef = new SoftReference<>(man);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   202
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   203
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   204
        return man;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   205
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   206
90ce3da70b43 Initial load
duke
parents:
diff changeset
   207
    private native String[] getMetaInfEntryNames();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   208
90ce3da70b43 Initial load
duke
parents:
diff changeset
   209
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   210
     * Returns the <code>JarEntry</code> for the given entry name or
90ce3da70b43 Initial load
duke
parents:
diff changeset
   211
     * <code>null</code> if not found.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   212
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   213
     * @param name the jar file entry name
90ce3da70b43 Initial load
duke
parents:
diff changeset
   214
     * @return the <code>JarEntry</code> for the given entry name or
90ce3da70b43 Initial load
duke
parents:
diff changeset
   215
     *         <code>null</code> if not found.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   216
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   217
     * @throws IllegalStateException
90ce3da70b43 Initial load
duke
parents:
diff changeset
   218
     *         may be thrown if the jar file has been closed
90ce3da70b43 Initial load
duke
parents:
diff changeset
   219
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   220
     * @see java.util.jar.JarEntry
90ce3da70b43 Initial load
duke
parents:
diff changeset
   221
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   222
    public JarEntry getJarEntry(String name) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   223
        return (JarEntry)getEntry(name);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   224
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   225
90ce3da70b43 Initial load
duke
parents:
diff changeset
   226
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   227
     * Returns the <code>ZipEntry</code> for the given entry name or
90ce3da70b43 Initial load
duke
parents:
diff changeset
   228
     * <code>null</code> if not found.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   229
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   230
     * @param name the jar file entry name
90ce3da70b43 Initial load
duke
parents:
diff changeset
   231
     * @return the <code>ZipEntry</code> for the given entry name or
90ce3da70b43 Initial load
duke
parents:
diff changeset
   232
     *         <code>null</code> if not found
90ce3da70b43 Initial load
duke
parents:
diff changeset
   233
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   234
     * @throws IllegalStateException
90ce3da70b43 Initial load
duke
parents:
diff changeset
   235
     *         may be thrown if the jar file has been closed
90ce3da70b43 Initial load
duke
parents:
diff changeset
   236
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   237
     * @see java.util.zip.ZipEntry
90ce3da70b43 Initial load
duke
parents:
diff changeset
   238
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   239
    public ZipEntry getEntry(String name) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   240
        ZipEntry ze = super.getEntry(name);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   241
        if (ze != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   242
            return new JarFileEntry(ze);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   243
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   244
        return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   245
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   246
17421
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   247
    private class JarEntryIterator implements Enumeration<JarEntry>,
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   248
            Iterator<JarEntry>
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   249
    {
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   250
        final Enumeration<? extends ZipEntry> e = JarFile.super.entries();
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   251
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   252
        public boolean hasNext() {
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   253
            return e.hasMoreElements();
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   254
        }
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   255
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   256
        public JarEntry next() {
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   257
            ZipEntry ze = e.nextElement();
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   258
            return new JarFileEntry(ze);
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   259
        }
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   260
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   261
        public boolean hasMoreElements() {
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   262
            return hasNext();
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   263
        }
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   264
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   265
        public JarEntry nextElement() {
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   266
            return next();
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   267
        }
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   268
    }
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   269
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   270
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   271
     * Returns an enumeration of the zip file entries.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   272
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   273
    public Enumeration<JarEntry> entries() {
17421
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   274
        return new JarEntryIterator();
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   275
    }
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   276
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   277
    @Override
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   278
    public Stream<JarEntry> stream() {
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   279
        return StreamSupport.stream(Spliterators.spliterator(
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   280
                new JarEntryIterator(), size(),
f3fbcfe6e2cf 8012645: Stream methods on BitSet, Random, ThreadLocalRandom, ZipFile
mduigou
parents: 16117
diff changeset
   281
                Spliterator.ORDERED | Spliterator.DISTINCT |
18822
4b6be7c19547 8019395: Consolidate StreamSupport.{stream,parallelStream} into a single method
psandoz
parents: 17421
diff changeset
   282
                        Spliterator.IMMUTABLE | Spliterator.NONNULL), false);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   283
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   284
90ce3da70b43 Initial load
duke
parents:
diff changeset
   285
    private class JarFileEntry extends JarEntry {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   286
        JarFileEntry(ZipEntry ze) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   287
            super(ze);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   288
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   289
        public Attributes getAttributes() throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   290
            Manifest man = JarFile.this.getManifest();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   291
            if (man != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   292
                return man.getAttributes(getName());
90ce3da70b43 Initial load
duke
parents:
diff changeset
   293
            } else {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   294
                return null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   295
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   296
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   297
        public Certificate[] getCertificates() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   298
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   299
                maybeInstantiateVerifier();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   300
            } catch (IOException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   301
                throw new RuntimeException(e);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   302
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   303
            if (certs == null && jv != null) {
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   304
                certs = jv.getCerts(JarFile.this, this);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   305
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   306
            return certs == null ? null : certs.clone();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   307
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   308
        public CodeSigner[] getCodeSigners() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   309
            try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   310
                maybeInstantiateVerifier();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   311
            } catch (IOException e) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   312
                throw new RuntimeException(e);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   313
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   314
            if (signers == null && jv != null) {
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   315
                signers = jv.getCodeSigners(JarFile.this, this);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   316
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   317
            return signers == null ? null : signers.clone();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   318
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   319
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   320
90ce3da70b43 Initial load
duke
parents:
diff changeset
   321
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   322
     * Ensures that the JarVerifier has been created if one is
90ce3da70b43 Initial load
duke
parents:
diff changeset
   323
     * necessary (i.e., the jar appears to be signed.) This is done as
90ce3da70b43 Initial load
duke
parents:
diff changeset
   324
     * a quick check to avoid processing of the manifest for unsigned
90ce3da70b43 Initial load
duke
parents:
diff changeset
   325
     * jars.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   326
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   327
    private void maybeInstantiateVerifier() throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   328
        if (jv != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   329
            return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   330
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   331
90ce3da70b43 Initial load
duke
parents:
diff changeset
   332
        if (verify) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   333
            String[] names = getMetaInfEntryNames();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   334
            if (names != null) {
22078
bdec5d53e98c 8030851: Update code in java.util to use newer language features
psandoz
parents: 19409
diff changeset
   335
                for (String nameLower : names) {
bdec5d53e98c 8030851: Update code in java.util to use newer language features
psandoz
parents: 19409
diff changeset
   336
                    String name = nameLower.toUpperCase(Locale.ENGLISH);
9365
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   337
                    if (name.endsWith(".DSA") ||
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   338
                        name.endsWith(".RSA") ||
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   339
                        name.endsWith(".EC") ||
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   340
                        name.endsWith(".SF")) {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   341
                        // Assume since we found a signature-related file
90ce3da70b43 Initial load
duke
parents:
diff changeset
   342
                        // that the jar is signed and that we therefore
90ce3da70b43 Initial load
duke
parents:
diff changeset
   343
                        // need a JarVerifier and Manifest
90ce3da70b43 Initial load
duke
parents:
diff changeset
   344
                        getManifest();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   345
                        return;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   346
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   347
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   348
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   349
            // No signature-related files; don't instantiate a
90ce3da70b43 Initial load
duke
parents:
diff changeset
   350
            // verifier
90ce3da70b43 Initial load
duke
parents:
diff changeset
   351
            verify = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   352
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   353
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   354
90ce3da70b43 Initial load
duke
parents:
diff changeset
   355
90ce3da70b43 Initial load
duke
parents:
diff changeset
   356
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   357
     * Initializes the verifier object by reading all the manifest
90ce3da70b43 Initial load
duke
parents:
diff changeset
   358
     * entries and passing them to the verifier.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   359
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   360
    private void initializeVerifier() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   361
        ManifestEntryVerifier mev = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   362
90ce3da70b43 Initial load
duke
parents:
diff changeset
   363
        // Verify "META-INF/" entries...
90ce3da70b43 Initial load
duke
parents:
diff changeset
   364
        try {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   365
            String[] names = getMetaInfEntryNames();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   366
            if (names != null) {
22078
bdec5d53e98c 8030851: Update code in java.util to use newer language features
psandoz
parents: 19409
diff changeset
   367
                for (String name : names) {
22578
ff8d54ac7c5c 8031572: jarsigner -verify exits with 0 when a jar file is not properly signed
weijun
parents: 22342
diff changeset
   368
                    String uname = name.toUpperCase(Locale.ENGLISH);
ff8d54ac7c5c 8031572: jarsigner -verify exits with 0 when a jar file is not properly signed
weijun
parents: 22342
diff changeset
   369
                    if (MANIFEST_NAME.equals(uname)
ff8d54ac7c5c 8031572: jarsigner -verify exits with 0 when a jar file is not properly signed
weijun
parents: 22342
diff changeset
   370
                            || SignatureFileVerifier.isBlockOrSF(uname)) {
ff8d54ac7c5c 8031572: jarsigner -verify exits with 0 when a jar file is not properly signed
weijun
parents: 22342
diff changeset
   371
                        JarEntry e = getJarEntry(name);
ff8d54ac7c5c 8031572: jarsigner -verify exits with 0 when a jar file is not properly signed
weijun
parents: 22342
diff changeset
   372
                        if (e == null) {
ff8d54ac7c5c 8031572: jarsigner -verify exits with 0 when a jar file is not properly signed
weijun
parents: 22342
diff changeset
   373
                            throw new JarException("corrupted jar file");
ff8d54ac7c5c 8031572: jarsigner -verify exits with 0 when a jar file is not properly signed
weijun
parents: 22342
diff changeset
   374
                        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   375
                        if (mev == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   376
                            mev = new ManifestEntryVerifier
90ce3da70b43 Initial load
duke
parents:
diff changeset
   377
                                (getManifestFromReference());
90ce3da70b43 Initial load
duke
parents:
diff changeset
   378
                        }
9365
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   379
                        byte[] b = getBytes(e);
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   380
                        if (b != null && b.length > 0) {
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   381
                            jv.beginEntry(e, mev);
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   382
                            jv.update(b.length, b, 0, b.length, mev);
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   383
                            jv.update(-1, null, 0, 0, mev);
469cd39a25de 7040803: regression: bugster fail to start
igor
parents: 9248
diff changeset
   384
                        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   385
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   386
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   387
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   388
        } catch (IOException ex) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   389
            // if we had an error parsing any blocks, just
90ce3da70b43 Initial load
duke
parents:
diff changeset
   390
            // treat the jar file as being unsigned
90ce3da70b43 Initial load
duke
parents:
diff changeset
   391
            jv = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   392
            verify = false;
16082
a042f1412a78 8000210: Improve JarFile code quality
weijun
parents: 11274
diff changeset
   393
            if (JarVerifier.debug != null) {
a042f1412a78 8000210: Improve JarFile code quality
weijun
parents: 11274
diff changeset
   394
                JarVerifier.debug.println("jarfile parsing error!");
a042f1412a78 8000210: Improve JarFile code quality
weijun
parents: 11274
diff changeset
   395
                ex.printStackTrace();
a042f1412a78 8000210: Improve JarFile code quality
weijun
parents: 11274
diff changeset
   396
            }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   397
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   398
90ce3da70b43 Initial load
duke
parents:
diff changeset
   399
        // if after initializing the verifier we have nothing
90ce3da70b43 Initial load
duke
parents:
diff changeset
   400
        // signed, we null it out.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   401
90ce3da70b43 Initial load
duke
parents:
diff changeset
   402
        if (jv != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   403
90ce3da70b43 Initial load
duke
parents:
diff changeset
   404
            jv.doneWithMeta();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   405
            if (JarVerifier.debug != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   406
                JarVerifier.debug.println("done with meta!");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   407
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   408
90ce3da70b43 Initial load
duke
parents:
diff changeset
   409
            if (jv.nothingToVerify()) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   410
                if (JarVerifier.debug != null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   411
                    JarVerifier.debug.println("nothing to verify!");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   412
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   413
                jv = null;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   414
                verify = false;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   415
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   416
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   417
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   418
90ce3da70b43 Initial load
duke
parents:
diff changeset
   419
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   420
     * Reads all the bytes for a given entry. Used to process the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   421
     * META-INF files.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   422
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   423
    private byte[] getBytes(ZipEntry ze) throws IOException {
16082
a042f1412a78 8000210: Improve JarFile code quality
weijun
parents: 11274
diff changeset
   424
        try (InputStream is = super.getInputStream(ze)) {
a042f1412a78 8000210: Improve JarFile code quality
weijun
parents: 11274
diff changeset
   425
            return IOUtils.readFully(is, (int)ze.getSize(), true);
8553
46c2babb1e44 7021582: convert jar/zip code and tests to use try-with-resources
smarks
parents: 8387
diff changeset
   426
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   427
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   428
90ce3da70b43 Initial load
duke
parents:
diff changeset
   429
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   430
     * Returns an input stream for reading the contents of the specified
90ce3da70b43 Initial load
duke
parents:
diff changeset
   431
     * zip file entry.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   432
     * @param ze the zip file entry
90ce3da70b43 Initial load
duke
parents:
diff changeset
   433
     * @return an input stream for reading the contents of the specified
90ce3da70b43 Initial load
duke
parents:
diff changeset
   434
     *         zip file entry
90ce3da70b43 Initial load
duke
parents:
diff changeset
   435
     * @throws ZipException if a zip file format error has occurred
90ce3da70b43 Initial load
duke
parents:
diff changeset
   436
     * @throws IOException if an I/O error has occurred
90ce3da70b43 Initial load
duke
parents:
diff changeset
   437
     * @throws SecurityException if any of the jar file entries
90ce3da70b43 Initial load
duke
parents:
diff changeset
   438
     *         are incorrectly signed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   439
     * @throws IllegalStateException
90ce3da70b43 Initial load
duke
parents:
diff changeset
   440
     *         may be thrown if the jar file has been closed
90ce3da70b43 Initial load
duke
parents:
diff changeset
   441
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   442
    public synchronized InputStream getInputStream(ZipEntry ze)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   443
        throws IOException
90ce3da70b43 Initial load
duke
parents:
diff changeset
   444
    {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   445
        maybeInstantiateVerifier();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   446
        if (jv == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   447
            return super.getInputStream(ze);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   448
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   449
        if (!jvInitialized) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   450
            initializeVerifier();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   451
            jvInitialized = true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   452
            // could be set to null after a call to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   453
            // initializeVerifier if we have nothing to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   454
            // verify
90ce3da70b43 Initial load
duke
parents:
diff changeset
   455
            if (jv == null)
90ce3da70b43 Initial load
duke
parents:
diff changeset
   456
                return super.getInputStream(ze);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   457
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   458
90ce3da70b43 Initial load
duke
parents:
diff changeset
   459
        // wrap a verifier stream around the real stream
90ce3da70b43 Initial load
duke
parents:
diff changeset
   460
        return new JarVerifier.VerifierStream(
90ce3da70b43 Initial load
duke
parents:
diff changeset
   461
            getManifestFromReference(),
90ce3da70b43 Initial load
duke
parents:
diff changeset
   462
            ze instanceof JarFileEntry ?
90ce3da70b43 Initial load
duke
parents:
diff changeset
   463
            (JarEntry) ze : getJarEntry(ze.getName()),
90ce3da70b43 Initial load
duke
parents:
diff changeset
   464
            super.getInputStream(ze),
90ce3da70b43 Initial load
duke
parents:
diff changeset
   465
            jv);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   466
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   467
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   468
    // Statics for hand-coded Boyer-Moore search
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   469
    private static final char[] CLASSPATH_CHARS = {'c','l','a','s','s','-','p','a','t','h'};
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   470
    // The bad character shift for "class-path"
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   471
    private static final int[] CLASSPATH_LASTOCC;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   472
    // The good suffix shift for "class-path"
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   473
    private static final int[] CLASSPATH_OPTOSFT;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   474
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   475
    static {
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   476
        CLASSPATH_LASTOCC = new int[128];
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   477
        CLASSPATH_OPTOSFT = new int[10];
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   478
        CLASSPATH_LASTOCC[(int)'c'] = 1;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   479
        CLASSPATH_LASTOCC[(int)'l'] = 2;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   480
        CLASSPATH_LASTOCC[(int)'s'] = 5;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   481
        CLASSPATH_LASTOCC[(int)'-'] = 6;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   482
        CLASSPATH_LASTOCC[(int)'p'] = 7;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   483
        CLASSPATH_LASTOCC[(int)'a'] = 8;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   484
        CLASSPATH_LASTOCC[(int)'t'] = 9;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   485
        CLASSPATH_LASTOCC[(int)'h'] = 10;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   486
        for (int i=0; i<9; i++)
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   487
            CLASSPATH_OPTOSFT[i] = 10;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   488
        CLASSPATH_OPTOSFT[9]=1;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   489
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   490
90ce3da70b43 Initial load
duke
parents:
diff changeset
   491
    private JarEntry getManEntry() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   492
        if (manEntry == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   493
            // First look up manifest entry using standard name
90ce3da70b43 Initial load
duke
parents:
diff changeset
   494
            manEntry = getJarEntry(MANIFEST_NAME);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   495
            if (manEntry == null) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   496
                // If not found, then iterate through all the "META-INF/"
90ce3da70b43 Initial load
duke
parents:
diff changeset
   497
                // entries to find a match.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   498
                String[] names = getMetaInfEntryNames();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   499
                if (names != null) {
22078
bdec5d53e98c 8030851: Update code in java.util to use newer language features
psandoz
parents: 19409
diff changeset
   500
                    for (String name : names) {
bdec5d53e98c 8030851: Update code in java.util to use newer language features
psandoz
parents: 19409
diff changeset
   501
                        if (MANIFEST_NAME.equals(name.toUpperCase(Locale.ENGLISH))) {
bdec5d53e98c 8030851: Update code in java.util to use newer language features
psandoz
parents: 19409
diff changeset
   502
                            manEntry = getJarEntry(name);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   503
                            break;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   504
                        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   505
                    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   506
                }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   507
            }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   508
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   509
        return manEntry;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   510
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   511
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   512
   /**
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   513
    * Returns {@code true} iff this JAR file has a manifest with the
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   514
    * Class-Path attribute
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   515
    */
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   516
    boolean hasClassPathAttribute() throws IOException {
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   517
        checkForSpecialAttributes();
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   518
        return hasClassPathAttribute;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   519
    }
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   520
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   521
    /**
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   522
     * Returns true if the pattern {@code src} is found in {@code b}.
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   523
     * The {@code lastOcc} and {@code optoSft} arrays are the precomputed
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   524
     * bad character and good suffix shifts.
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   525
     */
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   526
    private boolean match(char[] src, byte[] b, int[] lastOcc, int[] optoSft) {
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   527
        int len = src.length;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   528
        int last = b.length - len;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   529
        int i = 0;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   530
        next:
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   531
        while (i<=last) {
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   532
            for (int j=(len-1); j>=0; j--) {
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   533
                char c = (char) b[i+j];
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   534
                c = (((c-'A')|('Z'-c)) >= 0) ? (char)(c + 32) : c;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   535
                if (c != src[j]) {
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   536
                    i += Math.max(j + 1 - lastOcc[c&0x7F], optoSft[j]);
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   537
                    continue next;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   538
                 }
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   539
            }
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   540
            return true;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   541
        }
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   542
        return false;
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   543
    }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   544
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   545
    /**
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   546
     * On first invocation, check if the JAR file has the Class-Path
19409
d7c7b9d56631 8022921: Remove experimental Profile attribute
alanb
parents: 19047
diff changeset
   547
     * attribute. A no-op on subsequent calls.
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   548
     */
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   549
    private void checkForSpecialAttributes() throws IOException {
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   550
        if (hasCheckedSpecialAttributes) return;
27565
729f9700483a 8049367: Modular Run-Time Images
chegar
parents: 25859
diff changeset
   551
        JarEntry manEntry = getManEntry();
729f9700483a 8049367: Modular Run-Time Images
chegar
parents: 25859
diff changeset
   552
        if (manEntry != null) {
729f9700483a 8049367: Modular Run-Time Images
chegar
parents: 25859
diff changeset
   553
            byte[] b = getBytes(manEntry);
729f9700483a 8049367: Modular Run-Time Images
chegar
parents: 25859
diff changeset
   554
            if (match(CLASSPATH_CHARS, b, CLASSPATH_LASTOCC, CLASSPATH_OPTOSFT))
729f9700483a 8049367: Modular Run-Time Images
chegar
parents: 25859
diff changeset
   555
                hasClassPathAttribute = true;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   556
        }
16023
58ecc1b8327b 8008290: (profiles) Startup regression due to additional checking of JAR file manifests
alanb
parents: 11274
diff changeset
   557
        hasCheckedSpecialAttributes = true;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   558
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   559
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   560
    private synchronized void ensureInitialization() {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   561
        try {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   562
            maybeInstantiateVerifier();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   563
        } catch (IOException e) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   564
            throw new RuntimeException(e);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   565
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   566
        if (jv != null && !jvInitialized) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   567
            initializeVerifier();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   568
            jvInitialized = true;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   569
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   570
    }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   571
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   572
    JarEntry newEntry(ZipEntry ze) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   573
        return new JarFileEntry(ze);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   574
    }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   575
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   576
    Enumeration<String> entryNames(CodeSource[] cs) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   577
        ensureInitialization();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   578
        if (jv != null) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   579
            return jv.entryNames(this, cs);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   580
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   581
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   582
        /*
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   583
         * JAR file has no signed content. Is there a non-signing
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   584
         * code source?
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   585
         */
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   586
        boolean includeUnsigned = false;
22078
bdec5d53e98c 8030851: Update code in java.util to use newer language features
psandoz
parents: 19409
diff changeset
   587
        for (CodeSource c : cs) {
bdec5d53e98c 8030851: Update code in java.util to use newer language features
psandoz
parents: 19409
diff changeset
   588
            if (c.getCodeSigners() == null) {
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   589
                includeUnsigned = true;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   590
                break;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   591
            }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   592
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   593
        if (includeUnsigned) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   594
            return unsignedEntryNames();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   595
        } else {
29986
97167d851fc4 8078467: Update core libraries to use diamond with anonymous classes
darcy
parents: 27565
diff changeset
   596
            return new Enumeration<>() {
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   597
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   598
                public boolean hasMoreElements() {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   599
                    return false;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   600
                }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   601
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   602
                public String nextElement() {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   603
                    throw new NoSuchElementException();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   604
                }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   605
            };
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   606
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   607
    }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   608
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   609
    /**
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   610
     * Returns an enumeration of the zip file entries
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   611
     * excluding internal JAR mechanism entries and including
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   612
     * signed entries missing from the ZIP directory.
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   613
     */
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   614
    Enumeration<JarEntry> entries2() {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   615
        ensureInitialization();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   616
        if (jv != null) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   617
            return jv.entries2(this, super.entries());
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   618
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   619
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   620
        // screen out entries which are never signed
11274
7e7196757acd 7117249: fix warnings in java.util.jar, .logging, .prefs, .zip
smarks
parents: 9365
diff changeset
   621
        final Enumeration<? extends ZipEntry> enum_ = super.entries();
29986
97167d851fc4 8078467: Update core libraries to use diamond with anonymous classes
darcy
parents: 27565
diff changeset
   622
        return new Enumeration<>() {
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   623
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   624
            ZipEntry entry;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   625
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   626
            public boolean hasMoreElements() {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   627
                if (entry != null) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   628
                    return true;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   629
                }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   630
                while (enum_.hasMoreElements()) {
11274
7e7196757acd 7117249: fix warnings in java.util.jar, .logging, .prefs, .zip
smarks
parents: 9365
diff changeset
   631
                    ZipEntry ze = enum_.nextElement();
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   632
                    if (JarVerifier.isSigningRelated(ze.getName())) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   633
                        continue;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   634
                    }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   635
                    entry = ze;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   636
                    return true;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   637
                }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   638
                return false;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   639
            }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   640
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   641
            public JarFileEntry nextElement() {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   642
                if (hasMoreElements()) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   643
                    ZipEntry ze = entry;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   644
                    entry = null;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   645
                    return new JarFileEntry(ze);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   646
                }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   647
                throw new NoSuchElementException();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   648
            }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   649
        };
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   650
    }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   651
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   652
    CodeSource[] getCodeSources(URL url) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   653
        ensureInitialization();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   654
        if (jv != null) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   655
            return jv.getCodeSources(this, url);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   656
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   657
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   658
        /*
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   659
         * JAR file has no signed content. Is there a non-signing
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   660
         * code source?
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   661
         */
11274
7e7196757acd 7117249: fix warnings in java.util.jar, .logging, .prefs, .zip
smarks
parents: 9365
diff changeset
   662
        Enumeration<String> unsigned = unsignedEntryNames();
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   663
        if (unsigned.hasMoreElements()) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   664
            return new CodeSource[]{JarVerifier.getUnsignedCS(url)};
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   665
        } else {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   666
            return null;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   667
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   668
    }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   669
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   670
    private Enumeration<String> unsignedEntryNames() {
11274
7e7196757acd 7117249: fix warnings in java.util.jar, .logging, .prefs, .zip
smarks
parents: 9365
diff changeset
   671
        final Enumeration<JarEntry> entries = entries();
29986
97167d851fc4 8078467: Update core libraries to use diamond with anonymous classes
darcy
parents: 27565
diff changeset
   672
        return new Enumeration<>() {
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   673
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   674
            String name;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   675
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   676
            /*
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   677
             * Grab entries from ZIP directory but screen out
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   678
             * metadata.
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   679
             */
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   680
            public boolean hasMoreElements() {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   681
                if (name != null) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   682
                    return true;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   683
                }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   684
                while (entries.hasMoreElements()) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   685
                    String value;
11274
7e7196757acd 7117249: fix warnings in java.util.jar, .logging, .prefs, .zip
smarks
parents: 9365
diff changeset
   686
                    ZipEntry e = entries.nextElement();
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   687
                    value = e.getName();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   688
                    if (e.isDirectory() || JarVerifier.isSigningRelated(value)) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   689
                        continue;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   690
                    }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   691
                    name = value;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   692
                    return true;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   693
                }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   694
                return false;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   695
            }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   696
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   697
            public String nextElement() {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   698
                if (hasMoreElements()) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   699
                    String value = name;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   700
                    name = null;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   701
                    return value;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   702
                }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   703
                throw new NoSuchElementException();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   704
            }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   705
        };
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   706
    }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   707
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   708
    CodeSource getCodeSource(URL url, String name) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   709
        ensureInitialization();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   710
        if (jv != null) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   711
            if (jv.eagerValidation) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   712
                CodeSource cs = null;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   713
                JarEntry je = getJarEntry(name);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   714
                if (je != null) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   715
                    cs = jv.getCodeSource(url, this, je);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   716
                } else {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   717
                    cs = jv.getCodeSource(url, name);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   718
                }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   719
                return cs;
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   720
            } else {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   721
                return jv.getCodeSource(url, name);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   722
            }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   723
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   724
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   725
        return JarVerifier.getUnsignedCS(url);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   726
    }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   727
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   728
    void setEagerValidation(boolean eager) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   729
        try {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   730
            maybeInstantiateVerifier();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   731
        } catch (IOException e) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   732
            throw new RuntimeException(e);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   733
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   734
        if (jv != null) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   735
            jv.setEagerValidation(eager);
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   736
        }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   737
    }
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   738
11274
7e7196757acd 7117249: fix warnings in java.util.jar, .logging, .prefs, .zip
smarks
parents: 9365
diff changeset
   739
    List<Object> getManifestDigests() {
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   740
        ensureInitialization();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   741
        if (jv != null) {
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   742
            return jv.getManifestDigests();
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   743
        }
22078
bdec5d53e98c 8030851: Update code in java.util to use newer language features
psandoz
parents: 19409
diff changeset
   744
        return new ArrayList<>();
8387
f0fa7bbf889e 6742654: Code insertion/replacement attacks against signed jars
weijun
parents: 5506
diff changeset
   745
    }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   746
}