3

maven-jarsigner-plugin用来签署我的一个有阴影的超级罐子。不过,我确实需要在他们自己的 jar 中分发一些依赖项,并希望从 Maven 存储库中获取这些 jar,清除它们的任何现有签名,并用我自己的证书对其进行签名。

是否有任何 Maven 插件可以做到这一点,或者我会涉及一些 Ant 插件黑客?

4

4 回答 4

5

结果maven-jarsigner-plugin可以使用它的配置元素重新签署现有的 jars 。removeExistingSignatures很简单!

我使用在阶段maven-dependency-plugin将工件复制到 .war 项目中generate-resources,然后在process-resources阶段对它们进行签名。

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-dependency-plugin</artifactId>
    <version>2.8</version>
    <executions>
        <execution>
            <id>copy</id>
            <phase>generate-resources</phase>
            <goals>
                <goal>copy</goal>
            </goals>
            <configuration>
                <artifactItems>
                    <artifactItem>
                        <groupId>org.lwjgl.lwjgl</groupId>
                        <artifactId>lwjgl-platform</artifactId>
                        <version>2.9.0</version>
                        <classifier>natives-osx</classifier>
                        <type>jar</type>
                        <overWrite>true</overWrite>
                        <outputDirectory>src/main/webapp/</outputDirectory>
                        <destFileName>lwjgl-platform-natives-osx.jar</destFileName>
                    </artifactItem>   
                </artifactItems>        
                <outputDirectory>src/main/webapp</outputDirectory>
                <overWriteReleases>true</overWriteReleases>
                <overWriteSnapshots>true</overWriteSnapshots>
            </configuration>
        </execution>
    </executions>
</plugin>

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-jarsigner-plugin</artifactId>
    <version>1.2</version>
    <executions>
        <execution>
            <id>sign</id>
            <phase>process-resources</phase>
        <goals>
            <goal>sign</goal>
            </goals>
    </execution>
    </executions>
    <configuration>
        <keystore>${basedir}/path/to/my.keystore</keystore>
        <alias>alias</alias>
        <storepass>password</storepass>
        <keypass>password</keypass>
        <verbose>true</verbose>
        <archiveDirectory>src/main/webapp/</archiveDirectory>
        <processMainArtifact>false</processMainArtifact>
        <removeExistingSignatures>true</removeExistingSignatures>
    </configuration>
</plugin>
于 2014-01-21T09:12:52.067 回答
3

我知道这不是一个很好的答案,但我会在以下步骤中尝试解决方案:

  • 复制依赖项maven-dependency-plugin
  • antrun<unzip>他们,从 /META-INF 目录中删除除 MANIFEST.MF 之外的所有内容,<jar>然后再次使用<jarsign>ant 任务对其进行签名。

自从我使用 maven(最近我承认)以来,我发现的主要问题是它让你通过其预定义的管道,而这种事情(这比看起来更常见)会让你需要一些 ant 黑客,因为你叫它;)

于 2014-01-09T19:36:04.823 回答
2

从未使用过它,但似乎 webstart-maven-plugin 可以取消签名和签名 jars。

http://mojo.codehaus.org/webstart/webstart-maven-plugin/unsign-mojo.html

希望这有帮助。

于 2014-01-14T10:43:32.583 回答
2

使用行家:

为每个要退出的 jar 创建一个空的 maven jar 模块,执行 maven依赖:解压缩其中一个 jar,过滤签名文件并将文件复制到 src/main/java。

然后用 对 jar 进行签名maven-jarsigned-plugin,结果将是一个包含相同类的 jar。

另一种基于非 Maven 的:

上述方式不能很好地扩展,创建一个遵循这些步骤的脚本可能会更简单。

最简单的方法是:

考虑在您的 maven 存储库中注册签名者的公钥,而不是对 jars 进行签名,这意味着您信任创建这些 jars 的人并接受来自他们的任何 jars。

事实是您已经信任他们,因为您正在使用他们的代码并对其进行签名,因此配置存储库以接受他们的签名会更简单,就像有人已经将存储库配置为接受您的签名一样。

存储库链接到包含接受的 jar 签名者的公钥的密钥库,这将是要求处理存储库的团队向他们的受信任签名者列表中添加一个密钥的问题,他们会知道如何做到这一点当然。

于 2014-01-14T20:55:02.870 回答