HTTPURLConnection의 보안 리디렉션 문제
Java에서 HttpURLConnection은 HTTP에서 HTTPS URL로 전환하는 HTTP 리디렉션을 따를 때 어려움을 겪습니다. 특정 시나리오에서 관찰된 이 동작은 근본적인 원인을 이해하려는 개발자를 당황하게 했습니다.
문제를 설명하려면 다음 코드 조각을 고려하십시오.
import java.net.URL; import java.net.HttpURLConnection; import java.io.InputStream; public class Tester { public static void main(String argv[]) throws Exception{ InputStream is = null; try { String httpUrl = "http://httpstat.us/301"; URL resourceUrl = new URL(httpUrl); HttpURLConnection conn = (HttpURLConnection)resourceUrl.openConnection(); conn.setConnectTimeout(15000); conn.setReadTimeout(15000); conn.connect(); is = conn.getInputStream(); System.out.println("Original URL: "+httpUrl); System.out.println("Connected to: "+conn.getURL()); System.out.println("HTTP response code received: "+conn.getResponseCode()); System.out.println("HTTP response message received: "+conn.getResponseMessage()); } finally { if (is != null) is.close(); } } }
이 프로그램을 초기 URL이 "http://httpstat.us/301"로 설정되어 있으면 출력에 Java의 HttpURLConnection이 다음으로의 리디렉션을 따르지 않는 것으로 나타납니다. "https://httpstat.us."
동작 이해
이 동작에 대한 설명은 Java가 리디렉션을 처리하는 방식에 있습니다. 기본적으로 리디렉션은 동일한 프로토콜을 사용하는 경우에만 수행됩니다. 이 제한 사항은 followRedirect() 메서드에서 구현됩니다.
HTTPS는 HTTP를 모방하지만 프로토콜 관점에서 HTTP와는 별개의 프로토콜로 간주된다는 점에 유의하는 것이 중요합니다. 결과적으로 Java에서는 HTTP에서 HTTPS로의 리디렉션을 따르려면 사용자 승인이 필요합니다. 이 예방 조치는 잠재적인 보안 문제를 방지하기 위해 필요합니다.
예를 들어 익명 검색에 HTTP를 사용하는 동안 클라이언트가 자동 클라이언트 인증으로 구성된 경우 명시적인 사용자 동의 없이 HTTPS 리디렉션을 따르면 클라이언트의 신원이 다음 대상에 노출됩니다. 서버입니다.
위 내용은 Java의 HttpURLConnection이 기본적으로 HTTP에서 HTTPS로의 리디렉션을 따르지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

드림위버 CS6
시각적 웹 개발 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.
