首頁 > Java > java教程 > 為什麼 Java 的 HttpURLConnection 無法遵循 HTTP 到 HTTPS 重定向?

為什麼 Java 的 HttpURLConnection 無法遵循 HTTP 到 HTTPS 重定向?

DDD
發布: 2024-12-06 21:28:17
原創
511 人瀏覽過

Why Does Java's HttpURLConnection Fail to Follow HTTP to HTTPS Redirects?

從HTTP 到HTTPS 的HTTP 重定向導致連線失敗

嘗試使用Java 的HttpURL 從HTTP 重定向到HTTPS 時,可能會意外發生失敗。出現此問題的原因是 HttpURLConnection 的 followRedirect() 方法僅遵循相同協定內的重定向。

在提供的程式碼中,向「http://httpstat.us/301」發出請求,該請求傳回 301 Moved永久回應指示重定向到 URL 的 HTTPS 版本。但是,HttpURLConnection 不遵循此重定向。

為什麼會發生這種情況? HTTP 協定規格將 HTTP 和 HTTPS 視為不同的協定。儘管 HTTPS 與 HTTP 非常相似,但它在 HTTP 框架內缺乏官方認可。因此,出於安全原因,HttpURLConnection 在無需額外配置的情況下被設計為將 HTTPS 視為不同的協定。

未經使用者同意在 HTTP 和 HTTPS 之間進行重定向可能會帶來安全風險。例如,可能會自動為 HTTP 連線啟用用戶端身份驗證,但使用者可能打算匿名瀏覽。如果連線自動遵循 HTTPS 重新導向,則使用者的身分可能會無意中洩漏給伺服器。

因此,為了維護安全性,HttpURLConnection 預設不遵循從 HTTP 到 HTTPS 的重定向。此行為無法停用,在 Java 程式中使用 HTTP 重定向時了解此限制非常重要。

以上是為什麼 Java 的 HttpURLConnection 無法遵循 HTTP 到 HTTPS 重定向?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板