쿠키를 사용한 PHP 크로스 도메인 점프
웹 페이지를 개발할 때 많은 경우 다른 도메인 이름으로 점프해야 합니다. 예를 들어 도메인 이름 A의 웹 페이지에서 도메인 이름 B의 웹 페이지로 점프하는 경우는 다음과 같습니다. 도메인 간 점프가 필요합니다. 그러나 도메인을 교차하는 동안 사용자의 로그인 정보를 유지해야 하는 경우 교차 도메인 점프 중에 쿠키를 가져와야 합니다. 다음은 쿠키를 사용하여 교차 도메인 점프를 구현하는 PHP 방법입니다.
1. 배경지식
쿠키란 서버가 이용자의 브라우저에 보내는 작은 파일을 의미하며 이용자의 컴퓨터에 저장됩니다. 각 쿠키에는 만료 시간이 있으며 만료 후 자동으로 삭제됩니다.
웹 페이지에 로그인할 때, 사용자의 로그인 정보는 일반적으로 쿠키에 저장되므로 해당 웹 사이트의 다른 페이지를 방문할 때 다시 로그인할 필요가 없습니다.
한 도메인 이름의 웹 페이지가 다른 도메인 이름의 인터페이스나 리소스 호출을 요청하는 경우 교차 도메인 액세스가 필요합니다.
기존의 동일 출처 정책에서는 출처가 동일한(즉, 프로토콜, 도메인 이름, 포트 번호가 동일) 스크립트만 서로 접근할 수 있다고 규정하고 있습니다.
실제 개발에서는 다른 도메인 이름으로 점프해야 하는 경우가 많으며, 이를 위해서는 도메인 간 점프가 필요합니다. 도메인 간 점프에는 점프가 성공하고 사용자의 로그인 정보가 유지되는지 확인하기 위한 몇 가지 추가 구성 및 코드 구현이 필요합니다.
2. PHP는 쿠키를 사용하여 도메인 간 점프를 구현합니다.
다음은 샘플 코드입니다. 이 코드는 도메인 이름 A의 웹 페이지에서 도메인 이름 B의 인터페이스로 점프하고 쿠키를 전달하여 사용자의 로그인을 확인합니다. . 정보는 손실되지 않습니다.
header("Access-Control-Allow-Credentials: true") // 도메인 간 쿠키 허용
header("Access-Control-Allow-Origin: http://www.b.com "); // 도메인 간 접근을 허용하는 도메인 이름
setcookie("userid", "123456", time() + 3600, "/", ".a.com"); // 쿠키 설정
$target_url = "http ://www.b.com/interface.php"; // 대상 점프 주소
header("Location: $target_url") // 점프
?>
코드에서 먼저 헤더( ) 기능 교차 도메인 쿠키 및 교차 도메인 액세스를 허용하는 도메인 이름이 설정됩니다. 그런 다음 setcookie() 함수를 통해 사용자 정보 쿠키가 설정됩니다. 네 번째 매개변수 "/"는 전체 웹사이트에서 쿠키에 접근할 수 있음을 나타내고, 다섯 번째 매개변수 ".a.com"은 해당 쿠키가 하위 도메인을 넘어 접근할 수 있음을 나타냅니다.
마지막으로 header() 함수를 사용하여 점프하고 대상 점프 주소 $target_url을 지정합니다.
3. 요약
PHP가 쿠키를 사용하여 도메인 간 점프를 구현할 때 도메인 간 액세스, 쿠키 설정 및 도메인 간 점프 구현을 비롯한 여러 측면을 고려해야 합니다. header() 함수를 사용하여 해당 구성을 구현하면 사용자의 로그인 상태를 유지하는 도메인 간 액세스 및 도메인 간 점프를 달성할 수 있습니다.
위 내용은 PHP에서 쿠키를 사용하여 도메인 간 점프를 구현하는 방법에 대해 이야기해 보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!