>백엔드 개발 >PHP 튜토리얼 >HTTPS 사이트에서 AJAX 호출에 대한 '혼합 콘텐츠 차단' 오류를 해결하는 방법은 무엇입니까?

HTTPS 사이트에서 AJAX 호출에 대한 '혼합 콘텐츠 차단' 오류를 해결하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-27 19:23:11267검색

How to Fix the

HTTPS 페이지에서 HTTP AJAX 작업에 대한 "혼합 콘텐츠 차단" 오류 해결

HTTPS 페이지에서 HTTP AJAX 작업을 수행하려고 하면 " 혼합 콘텐츠가 차단되었습니다' 오류가 발생했습니다. 이는 브라우저가 보안 HTTPS 페이지에서 이루어지는 안전하지 않은 HTTP 요청을 감지할 때 발생합니다.

이 문제를 해결하려면 다음 해결 방법을 사용할 수 있습니다.

1. 적절한 HTTP 방법 사용

대상 API가 HTTPS를 지원하는 경우 HTTPS 프로토콜을 사용하도록 AJAX 요청을 업데이트해야 합니다:

url: "https://XX.XXX.XX.XX/vicidial/non_agent_api.php",

2. 콘텐츠 보안 정책 메타 태그

API 프로토콜을 변경할 수 없는 경우 HTML 페이지에 다음 메타 태그를 추가하여 혼합 콘텐츠를 허용할 수 있습니다.

<meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests">

이렇게 하면 브라우저가 안전하지 않은 HTTP 요청을 HTTPS로 자동 업그레이드하도록 지시하여 혼합 콘텐츠 문제를 해결합니다.

3. 서버측 프록시 사용

이전 솔루션을 실행할 수 없는 경우 HTTP AJAX 요청을 수신하고 이를 HTTPS를 사용하여 대상 API에 전달하는 서버측 프록시 스크립트를 생성할 수 있습니다.

<?php
// Read and parse incoming data
$data = $_GET;

// Send data to API via HTTPS
$result = file_get_contents("https://XX.XXX.XX.XX/vicidial/non_agent_api.php?queries=" . http_build_query($data));

// Redirect user to thank-you page
header("Location: https://www.example.com/thank-you");
?>

위 내용은 HTTPS 사이트에서 AJAX 호출에 대한 '혼합 콘텐츠 차단' 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.