Scala:如何忽略'SSLHandshakeException'

use*_*r_x 6 ssl scala sslhandshakeexception

有了这样的代码:

val html = Source.fromURL("https://scans.io/json")
Run Code Online (Sandbox Code Playgroud)

获得例外:

Exception in thread "main" javax.net.ssl.SSLHandshakeException: sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target
at sun.security.ssl.Alerts.getSSLException(Alerts.java:192)
at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1886)
...
Run Code Online (Sandbox Code Playgroud)

我可以找到如何修复Java但不知道 - 如何在Scala中修复它?

Nad*_*ari 8

您可以通过配置a来实现此目的SSLContext.

这是一个有效的代码

import javax.net.ssl._
import java.security.cert.X509Certificate
import scala.io.Source

// Bypasses both client and server validation.
object TrustAll extends X509TrustManager {
  val getAcceptedIssuers = null

  def checkClientTrusted(x509Certificates: Array[X509Certificate], s: String) = {}

  def checkServerTrusted(x509Certificates: Array[X509Certificate], s: String) = {}
}

// Verifies all host names by simply returning true.
object VerifiesAllHostNames extends HostnameVerifier {
  def verify(s: String, sslSession: SSLSession) = true
}

// Main class
object Test extends App {
  // SSL Context initialization and configuration
  val sslContext = SSLContext.getInstance("SSL")
  sslContext.init(null, Array(TrustAll), new java.security.SecureRandom())
  HttpsURLConnection.setDefaultSSLSocketFactory(sslContext.getSocketFactory)
  HttpsURLConnection.setDefaultHostnameVerifier(VerifiesAllHostNames)

  // Actual call
  val html = Source.fromURL("https://scans.io/json")
  println(html.mkString)
}
Run Code Online (Sandbox Code Playgroud)

这个怎么运作

Source.fromURLjava.net.HttpURLConnection在幕后使用.所以这段代码很简单,因为TrustAll旁路checkClientTrustedcheckServerTrusted方法.

  • 顺便说一句,我永远不会这样做,特别是在生产中,除非你有一个真正的原因(临时,仅用于测试等) (3认同)