Browse Source
Update Gradle and Maven plugins to write an empty `META-INF/BOOT.SF`
file whenever there is a nested signed jar.
This update allows Oracle Java 17 to correctly verify the nested JARs.
The file is required because `JarVerifier` has code roughly equivalent
to:
if (!jarManifestNameChecked && SharedSecrets
.getJavaUtilZipFileAccess().getManifestName(jf, true) == null) {
throw new JarException("The JCE Provider " + jarURL.toString() +
" is not signed.");
}
The `SharedSecrets.getJavaUtilZipFileAccess().getManifestName(jf, true)`
call ends up in `ZipFile.getManifestName(onlyIfSignatureRelatedFiles)`
which is a private method that we cannot override in our `NestedJarFile`
subclass. By writing an empty `.SF` file we ensure that the `Manifest`
is always returned because there are always "signature related files".
Fixes gh-28837
pull/37915/head
17 changed files with 266 additions and 17 deletions
@ -0,0 +1,17 @@ |
|||||||
|
plugins { |
||||||
|
id 'java' |
||||||
|
id 'org.springframework.boot' version '{version}' |
||||||
|
} |
||||||
|
|
||||||
|
bootJar { |
||||||
|
mainClass = 'com.example.Application' |
||||||
|
} |
||||||
|
|
||||||
|
repositories { |
||||||
|
mavenCentral() |
||||||
|
maven { url "file:repository" } |
||||||
|
} |
||||||
|
|
||||||
|
dependencies { |
||||||
|
implementation("org.bouncycastle:bcprov-jdk18on:1.76") |
||||||
|
} |
||||||
@ -0,0 +1,9 @@ |
|||||||
|
Manifest-Version: 1.0 |
||||||
|
Created-By: 1.5.0_08 (Sun Microsystems Inc.) |
||||||
|
Specification-Version: 1.1 |
||||||
|
|
||||||
|
Name: org/bouncycastle/pqc/legacy/math/linearalgebra/GoppaCode.class |
||||||
|
SHA-256-Digest: wNhEfeTvNG9ggqKfLjQDDoFoDqeWwGUc47JiL7VqxqU= |
||||||
|
|
||||||
|
Name: org/bouncycastle/crypto/modes/gcm/Tables8kGCMMultiplier.class |
||||||
|
SHA-256-Digest: nqljr9DNx4nNie4sbkZajVenvd3LdMF3X5s5dmSMToM= |
||||||
@ -0,0 +1,62 @@ |
|||||||
|
<?xml version="1.0" encoding="UTF-8"?> |
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" |
||||||
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> |
||||||
|
<modelVersion>4.0.0</modelVersion> |
||||||
|
<groupId>org.springframework.boot.maven.it</groupId> |
||||||
|
<artifactId>jar-signed</artifactId> |
||||||
|
<version>0.0.1.BUILD-SNAPSHOT</version> |
||||||
|
<properties> |
||||||
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> |
||||||
|
<maven.compiler.source>@java.version@</maven.compiler.source> |
||||||
|
<maven.compiler.target>@java.version@</maven.compiler.target> |
||||||
|
</properties> |
||||||
|
<build> |
||||||
|
<plugins> |
||||||
|
<plugin> |
||||||
|
<groupId>@project.groupId@</groupId> |
||||||
|
<artifactId>@project.artifactId@</artifactId> |
||||||
|
<version>@project.version@</version> |
||||||
|
<executions> |
||||||
|
<execution> |
||||||
|
<goals> |
||||||
|
<goal>repackage</goal> |
||||||
|
</goals> |
||||||
|
</execution> |
||||||
|
</executions> |
||||||
|
</plugin> |
||||||
|
<plugin> |
||||||
|
<groupId>org.apache.maven.plugins</groupId> |
||||||
|
<artifactId>maven-jar-plugin</artifactId> |
||||||
|
<version>@maven-jar-plugin.version@</version> |
||||||
|
<configuration> |
||||||
|
<archive> |
||||||
|
<manifest> |
||||||
|
<mainClass>some.random.Main</mainClass> |
||||||
|
</manifest> |
||||||
|
<manifestEntries> |
||||||
|
<Not-Used>Foo</Not-Used> |
||||||
|
</manifestEntries> |
||||||
|
</archive> |
||||||
|
</configuration> |
||||||
|
</plugin> |
||||||
|
</plugins> |
||||||
|
</build> |
||||||
|
<dependencies> |
||||||
|
<dependency> |
||||||
|
<groupId>org.springframework</groupId> |
||||||
|
<artifactId>spring-context</artifactId> |
||||||
|
<version>@spring-framework.version@</version> |
||||||
|
</dependency> |
||||||
|
<dependency> |
||||||
|
<groupId>jakarta.servlet</groupId> |
||||||
|
<artifactId>jakarta.servlet-api</artifactId> |
||||||
|
<version>@jakarta-servlet.version@</version> |
||||||
|
<scope>provided</scope> |
||||||
|
</dependency> |
||||||
|
<dependency> |
||||||
|
<groupId>org.bouncycastle</groupId> |
||||||
|
<artifactId>bcprov-jdk18on</artifactId> |
||||||
|
<version>1.76</version> |
||||||
|
</dependency> |
||||||
|
</dependencies> |
||||||
|
</project> |
||||||
@ -0,0 +1,24 @@ |
|||||||
|
/* |
||||||
|
* Copyright 2012-2023 the original author or authors. |
||||||
|
* |
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||||
|
* you may not use this file except in compliance with the License. |
||||||
|
* You may obtain a copy of the License at |
||||||
|
* |
||||||
|
* https://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
* |
||||||
|
* Unless required by applicable law or agreed to in writing, software |
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||||
|
* See the License for the specific language governing permissions and |
||||||
|
* limitations under the License. |
||||||
|
*/ |
||||||
|
|
||||||
|
package org.test; |
||||||
|
|
||||||
|
public class SampleApplication { |
||||||
|
|
||||||
|
public static void main(String[] args) { |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
Loading…
Reference in new issue