Por que o despacho lança exceções “java.net.ConnectException: SSLEngine Geral…” e “status inesperado” para um URL específico?
Eu tenho o seguinte código não ativo:
object Main extends App {
import dispatch._
def test(address: String) = {
Await.result(Http.default(url(address).GET OK as.String), Duration.Inf)
}
// This works fine
val s1 = test("http://download.finance.yahoo.com/d/quotes.csv?s=MSFT&f=sohgbav")
println(s1)
// This throws Exception 1
val s2 = test("http://www.alphavantage.co/query?function=TIME_SERIES_DAILY_ADJUSTED&symbol=MSFT&apikey=demo&datatype=csv")
println(s2)
// This throws Exception 2
val s3 = test("https://www.alphavantage.co/query?function=TIME_SERIES_DAILY_ADJUSTED&symbol=MSFT&apikey=demo&datatype=csv")
println(s3)
}
Gostaria de saber por que "s1" funciona bem, enquanto "s2" e "s3" geram exceções. As exceções lançadas são:
Exceção 1:
[error] ! access URL
[error] java.util.concurrent.ExecutionException: dispatch.StatusCode: Unexpected response status: 301 (NettyResponseFuture.java:172)
[error] org.asynchttpclient.netty.NettyResponseFuture.get(NettyResponseFuture.java:172)
[error] dispatch.HttpExecutor.$anonfun$apply$3(execution.scala:123)
Exceção 2:
[error] ! access URL
[error] java.util.concurrent.ExecutionException: java.net.ConnectException: General SSLEngine problem (NettyResponseFuture.java:172)
[error] org.asynchttpclient.netty.NettyResponseFuture.get(NettyResponseFuture.java:172)
[error] dispatch.HttpExecutor.$anonfun$apply$3(execution.scala:123)
Além disso, todos os três URLs funcionam conforme o esperado quando eu os acesso através do navegador Safari. Por que o primeiro URL funciona bem através do envio, mas os dois últimos não?