无法使用scala的sbt从存储库中获取插件

问题描述 投票:2回答:1

我尝试使用sbt编译/构建scala项目,project / plugins.sbt中提到了两个插件:

addSbtPlugin("com.typesafe.play" % "sbt-plugin" % "2.6.17")
addSbtPlugin("com.typesafe.sbt" % "sbt-native-packager" % "1.3.4")

导入sbt项目时出错:

[error] sbt.librarymanagement.ResolveException: download failed: 
com.typesafe.play#sbt-plugin;2.6.17!sbt-plugin.jar
[error] download failed: com.typesafe.sbt#sbt-native-packager;1.3.4!sbt-native- 
packager.jar

似乎存储库的证书中存在问题,因此我手动获取每个证书并使用命令将其添加到我的密钥库(我使用ubuntu):

keytool -import -alias "artifact server2" -keystore /usr/lib/jvm/java-8-oracle/jre/lib/security/cacerts -file _.bintray.com

但它没有帮助。

更新:我通过手动将所有证书(结束和中间)从repo的主机添加到本地密钥库来解决了我的问题。

scala ubuntu ssl plugins sbt
1个回答
3
投票

这个问题让我几乎准备把我的macbook扔出窗外。

在我的Mac上,java cacerts位于:

/Library/Java/JavaVirtualMachines/jdk1.8.0_45.jdk/Contents/Home/jre/lib/security/cacerts

为了获得sbt-native-packager所需的证书,我使用了这个(我偷了一个人,现在我找不到归属地):

echo -n | openssl s_client -connect repo.scala-sbt.org:443 | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' > /tmp/scala-sbt.cert

然后将它添加到java信任库,我使用了Stanislav的解决方案:

sudo keytool -import -alias "scala-sbt server" -keystore /Library/Java/JavaVirtualMachines/jdk1.8.0_45.jdk/Contents/Home/jre/lib/security/cacerts -file /tmp/scala-sbt.cert

请记住,cacerts文件的默认密码是changeit

然后下次我运行插件下载的插件,我几乎哭了喜悦的泪水。

© www.soinside.com 2019 - 2024. All rights reserved.