scala – Akka HTTP 2.0使用SSL(HTTPS)
发布时间:2020-12-16 09:28:34 所属栏目:安全 来源:网络整理
导读:我正在尝试将自签名证书添加到我的配置中,以使我的Web服务通过SSL提供内容,但我没有运气. 这是我目前的配置 ssl { jksKeystore = "localhost.p12" password = "changeit"} 我有什么想法能够启动HTTPS服务器的任何想法? 我的项目是使用akka 2.0和scala 解决
我正在尝试将自签名证书添加到我的配置中,以使我的Web服务通过SSL提供内容,但我没有运气.
这是我目前的配置 ssl { jksKeystore = "localhost.p12" password = "changeit" } 我有什么想法能够启动HTTPS服务器的任何想法? 我的项目是使用akka 2.0和scala 解决方法
在akka代码库中有一些测试https功能的测试.它们使用
ExampleHttpContexts中定义的预定义http上下文.
我创建了一个小型仓库,它使用akka存储库中的密钥(我希望他们不会介意)并使用自签名证书here创建一个最小的https服务器.完成为repo而不是作为一个要点所以你可以克隆它开始. 这是scala代码: package httpsserver import java.security.{SecureRandom,KeyStore} import javax.net.ssl.{KeyManagerFactory,SSLContext} import akka.actor.ActorSystem import akka.http.scaladsl.{HttpsContext,Http} import akka.http.scaladsl.server.Directives._ import akka.http.scaladsl.server.Route import akka.stream.ActorMaterializer object Server extends App { val serverContext: HttpsContext = { val password = "abcdef".toCharArray val context = SSLContext.getInstance("TLS") val ks = KeyStore.getInstance("PKCS12") ks.load(getClass.getClassLoader.getResourceAsStream("keys/server.p12"),password) val keyManagerFactory = KeyManagerFactory.getInstance("SunX509") keyManagerFactory.init(ks,password) context.init(keyManagerFactory.getKeyManagers,null,new SecureRandom) // start up the web server HttpsContext(context) } implicit val system = ActorSystem("server") implicit val materializer = ActorMaterializer() import system._ val route = Route(complete("ok")) Http().bindAndHandle(route,interface = "0.0.0.0",port = 8081,httpsContext = Some(serverContext)) } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |