HTTP GET отвечает с пустым телом, загружает документ excel в IE
Я пытаюсь понять, что происходит на этой странице, Когда я загружаю отчет excel. Он работает только для Internet Explorer, и когда я пытаюсь загрузить отчет в Scala, используя ScalaJ, i входной поток для тела ответа равен нулю. Кто-нибудь может помочь мне понять, что здесь происходит?
Запрос открытого текста:
GET /oca_ReportViewer.aspx?ReportName=District_and_Statutory_County_Court/DSC_Civil_Family_Activity_Detail_N.rpt&ddlFromMonth=9&ddlFromYear=2010&txtFromMonthField=@FromMonth&txtFromYearField=@FromYear&ddlToMonth=10&ddlToYear=2010&txtToMonthField=@ToMonth&txtToYearField=@ToYear&ddlCountyPostBack=0&txtCountyPostBackField=@CountyID&chkAggregateMonthlyReport=0&export=1625 HTTP/1.1
Accept: text/html, application/xhtml+xml, image/jxr, */*
Referer: http://card.txcourts.gov/ReportSelection.aspx
Accept-Language: en-US
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko
Accept-Encoding: gzip, deflate
Host: card.txcourts.gov
Connection: Keep-Alive
Cache-Control: no-cache
Cookie: ASP.NET_SessionId=j0tgci45qj3t1uqygrvkqz55
Код до сих пор:
import java.io.{BufferedOutputStream, FileOutputStream, FileWriter, InputStream}
import scalaj.http._
object Downloader extends App {
val url = "http://card.txcourts.gov/oca_ReportViewer.aspx"
val keys: Map[String, String] = Map (
("ReportName", "District_and_Statutory_County_Court/DSC_Civil_Family_Activity_Detail_N.rpt"),
("ddlFromMonth", "9"),
("ddlFromYear", "2010"),
("txtFromMonthField", "@FromMonth"),
("txtFromYearField", "@FromYear"),
("ddlToMonth", "10"),
("ddlToYear", "2010"),
("txtToMonthField", "@ToMonth"),
("txtToYearField", "@ToYear"),
("ddlCountyPostBack", "0"),
("txtCountyPostBackField", "@CountyID"),
("chkAggregateMonthlyReport", "0"),
("export", "1625")
)
//println(keys)
val heads: Map[String, String] = Map (
("Accept", "text/html, application/xhtml+xml, image/jxr, */*"),
("Accept-Encoding", "gzip, deflate"),
("Accept-Language", "en-US"),
("Cache-Control", "no-cache"),
("Connection", "Keep-Alive"),
("Cookie", "ASP.NET_SessionId=j0tgci45qj3t1uqygrvkqz55"),
("Host", "card.txcourts.gov"),
("Referer", "http://card.txcourts.gov/ReportSelection.aspx"),
("User-Agent", "Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; rv:11.0) like Gecko")
)
def parse(status: Int, headers: Map[String, IndexedSeq[String]], inputStream: InputStream): Unit = {
val output = new BufferedOutputStream(new FileOutputStream("test.xls"))
val bytes = new Array[Byte](1024) //1024 bytes - Buffer size
//println(status)
//println(headers)
Stream
.continually (inputStream.read(bytes))
.takeWhile (-1 !=)
.foreach (read=>output.write(bytes,0,read))
output.close()
}
val response: HttpResponse[Unit] = Http(url).params(keys).headers(heads).charset("US-ASCII").timeout(1000, 60000).exec[Unit](parse)
println(response.isSuccess)
}
Если кто-нибудь может мне помочь, я буду очень признателен! Мне просто нужен ответ. сохранено до А.xls-файл. И если у вас есть время, я также не могу найти, где браузер берет идентификатор сеанса, так что это было бы действительно полезно выяснить.
Правка:
Я вижу, что данные excel действительно отправляются, проверьте этот поток, используя wireshark:
Спасибо!
1 ответ:
Ладно, не совсем понимаю, почему мой поток стал нулевым, но я изменил код, чтобы просто закрыть выходной поток, когда он попадет в исключение. Я знаю, что это глупо, но это сработало, и файл загружен полностью. Если кто-то еще знает лучшее объяснение, я был бы признателен!
Вот новая функция синтаксического анализа:
def parse(status: Int, headers: Map[String, IndexedSeq[String]], inputStream: InputStream): Unit = { val output = new BufferedOutputStream(new FileOutputStream(filename)) try { Iterator .continually (inputStream.read) .takeWhile (-1 !=) .foreach (output.write) } catch { case _: Throwable => output.close() } finally{ output.close() } }