최근 ajax
비동기 요청 관련 문제를 발견했습니다. $.post
, $.get
, $.ajax code를 사용하세요. >PHP 서버 요청 시 데이터를 비동기적으로 반환할 수 없습니다. <code>ajax
异步请求的问题,用$.post
、$.get
、$.ajax
请求PHP服务器时,总是无法异步返回数据。
经多次测试才发现:
– 不同浏览器,请求不同域名-不阻塞:无需实验
– 不同浏览器,请求同域名-不阻塞:session_id()
返回不同
– 同一浏览器,请求不同域名-不阻塞:session_id
返回不同
– 同一浏览器,请求同域名-阻塞:session_id()
返回相同
发现问题所在:
1 关闭XDEBUG
2 SESSION
锁
3 清除输出缓冲区
1 关闭XDEBUG
XDEBUG
是实时调试。调试时,它将保持FPM
以确保线程正在工作以避免数据污染。
典型的测试方法是,使用XDEBUG
进行调试时,打开另一个浏览器并访问该站点,该站点这个时候是无法访问的。
这对并行响应有重大影响,即,即使前端发送多个请求,它也受XDEBUG
控制,并且只能同时响应一个。
另外,由于XDEBUG
依赖于SESSION
,因此即使您使用session_write_close()
,也要关闭会话锁(请参见下文)。XDEBUG
仍会自动打开。
2 SESSION
锁
用 session_write_close()
关闭SESSION
的写锁,这适合SESSION
保存为File
的情况。如果SESSION
保存在Redis
,则不需要。
3 清除输出缓冲区
使用session_write_close()
可能无法立即关闭SESSION
锁,所以在这个方法之前加上:ob_end_flush()
。让 session_write_close()
马上生效。
4 示例
有如下一个范例,当点击【提交】按钮时,前端会给后台服务器发送两种请求。
一种是get
请求,每隔1秒请求一次。
一种是post
많은 테스트를 거친 후 다음 사항을 발견했습니다.
– 다양한 브라우저, 다양한 도메인 이름 요청 - 차단 없음: 실험할 필요 없음 – 다양한 브라우저, 동일한 도메인 이름 요청 - 차단 없음: session_id( )
는 다른 값을 반환합니다
session_id
는 다른 값을 반환합니다 – 동일한 브라우저, 동일한 도메인 이름 요청 – 차단: session_id() code>동일한 결과를 반환합니다문제 발견:1 XDEBUG
닫기2 SESSION
잠금
3 지우기 출력 버퍼
XDEBUG
🎜XDEBUG
는 실시간 디버깅입니다. 디버깅할 때 스레드가 데이터 오염을 방지하기 위해 작동하는지 확인하기 위해 FPM
을 유지합니다. 🎜일반적인 테스트 방법은 디버깅을 위해 XDEBUG
를 사용할 때 다른 브라우저를 열고 사이트에 액세스하는 것입니다. 🎜🎜이것은 병렬 응답에 상당한 영향을 미칩니다. 즉, 프런트엔드가 여러 요청을 보내더라도 XDEBUG
에 의해 제어되며 한 번에 하나씩만 응답할 수 있습니다. 🎜또한 XDEBUG
는 SESSION
에 의존하기 때문에 session_write_close()
를 사용해도 세션 잠금을 닫아야 합니다(아래 참조). XDEBUG
는 계속 자동으로 열립니다. 🎜🎜2 SESSION
잠금🎜session_write_close()
를 사용하여 SESSION
의 쓰기 잠금을 닫습니다. 세션
파일
로 저장하세요. SESSION
이 Redis
에 저장된 경우에는 필요하지 않습니다. 🎜🎜3 출력 버퍼 지우기🎜 session_write_close()
를 사용하면 SESSION
잠금이 즉시 닫히지 않을 수 있으므로 이 메서드 앞에 를 추가하세요. >ob_end_flush()
. session_write_close()
가 즉시 적용되도록 하세요. 🎜🎜4 예시🎜 [Submit] 버튼을 클릭하면 프런트엔드에서 백엔드 서버로 두 개의 요청을 보내는 예시가 있습니다. 🎜하나는 1초마다 요청되는 get
요청입니다. 🎜하나는 post
요청으로 처음에 한 번 전송된 후 해당 완료를 기다립니다. 🎜🎜HTML 코드 보기🎜<form> <input type="submit" value="提交" /> </form> <script src="//cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script> <script type="text/javascript"> $('form').on('submit', function(e) { e.preventDefault(); // 每隔一秒请求一次服务器 var id = setInterval(function() { $.get( 'save.php?action=get', {}, function(data) { console.log(data); }, 'json' ); }, 1000); $.post( 'save.php?action=post', {}, function(data) { console.log(data); // 停止定时循环 clearInterval(id); }, 'json' ); }); </script>
<?php session_start();$action = $_GET['action']; if ($action == 'post') { $_SESSION['time'] = 0; session_write_close(); while ($_SESSION['time'] < 5) { session_start(); $_SESSION['time'] = $_SESSION['time'] + 1; // 将SESSION数据写入文件中,并关闭写锁 session_write_close(); // sleep()模拟花费时间较长的程序,这样在关闭写锁之后, // 服务器就能够相应别的请求,如下的$action=get, sleep(1); } echo json_encode([session_id() => $_SESSION['time']]); exit();}if ($action == 'get') { echo json_encode([session_id() => $_SESSION['time']]); exit();}
위 내용은 데이터를 반환하지 않고 PHP 서버에 비동기 요청을 합니까? (해결책은 첨부했습니다)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!