利用Chrome的后台网络,分析了通过JQuery的$.ajax()把 json 数据 post 给 PHP时的几种情况:
无法在PHP中通过$_POST 以及 $_REQUEST 获取json数据,即
<span>$json</span> = <span>$_POST</span>['json']; <span>//</span><span> empty($json) 为1</span>注:PHP 默认只识别 application/x-www.form-urlencoded 标准的数据类型,因此,对型如 text/xml 或者 soap 或者 application/octet-stream 之类的内容无法解析,如果用 $_POST 数组来接收就会失败。
情况A:
js里没有加入属性contentType: "application/json; charset=utf-8",
<span>var</span> submit_sync = <span>function</span><span>() { $.ajax({ type: </span>"post"<span>, url: </span>'add-post-json.php'<span>, async: </span><span>false</span>, <span>//</span><span> 使用同步方式</span> <span>//</span><span> 1 需要使用JSON.stringify 否则格式为 a=2&b=3&now=14...</span> <span>//</span><span> 2 需要强制类型转换,否则格式为 {"a":"2","b":"3"}</span> <span> data: JSON.stringify({ a: parseInt($(</span>'input[name="a"]'<span>).val()), b: parseInt($(</span>'input[name="b"]'<span>).val()), now: </span><span>new</span> Date().getTime() <span>//</span><span> 注意不要在此行增加逗号</span> <span> }), dataType: </span>"json"<span>, success: </span><span>function</span><span>(data) { $(</span>'#result'<span>).text(data.result); } </span><span>//</span><span> 注意不要在此行增加逗号</span> <span> }); }</span>
- 使用 $GLOBALS['HTTP_RAW_POST_DATA'] 后无法获取到数据,即
<span>$json</span> = <span>$GLOBALS</span>['HTTP_RAW_POST_DATA']; <span>//</span><span> empty($json) 为 1</span>
- 使用file_get_contents("php://input"); 可以获取数据,即
<span>$json</span> = <span>file_get_contents</span>("php://input"); <span>//</span><span> empty($json) 为 0</span>
情况B:
js里加入属性contentType: "application/json; charset=utf-8",
<span>var</span> submit_sync = <span>function</span><span>() { $.ajax({ type: </span>"post"<span>, url: </span>'add-post-json.php'<span>, async: </span><span>false</span>, <span>//</span><span> 使用同步方式</span> <span>//</span><span> 1 需要使用JSON.stringify 否则格式为 a=2&b=3&now=14...</span> <span>//</span><span> 2 需要强制类型转换,否则格式为 {"a":"2","b":"3"}</span> <span> data: JSON.stringify({ a: parseInt($(</span>'input[name="a"]'<span>).val()), b: parseInt($(</span>'input[name="b"]'<span>).val()), now: </span><span>new</span> Date().getTime() <span>//</span><span> 注意不要在此行增加逗号</span> <span> }), <span>contentType: </span></span>"application/json; charset=utf-8"<span><span>,</span></span><em><span> dataType: </span>"json"<span>, success: </span><span>function</span><span>(data) { $(</span>'#result'<span>).text(data.result); } </span><span>//</span><span> 注意不要在此行增加逗号</span> <span> }); }</span></em>
- 使用 $GLOBALS['HTTP_RAW_POST_DATA'] 后可以获取到数据,即
<span>$json</span> = <span>$GLOBALS</span>['HTTP_RAW_POST_DATA']; <span>//</span><span> empty($json) 为 0</span>
- 使用file_get_contents("php://input"); 可以获取数据,即
<span>$json</span> = <span>file_get_contents</span>("php://input"); <span>//</span><span> empty($json) 为 0</span>注:php://input 允许读取 POST 的原始数据。和 $HTTP_RAW_POST_DATA 比起来,它给内存带来的压力较小,并且不需要任何特殊的 php.ini 设置。php://input 不能用于 enctype="multipart/form-data"。
情况C:
是否加入以下
<span>header</span>('Content-Type:application/json;charset=utf-8');对情况A与情况B的结果没有任何影响。
从5.2版本开始,PHP原生提供json_encode()和json_decode()函数,前者用于编码,后者用于解码。下面这篇博客写的很详细,mark!
在PHP语言中使用JSON:http://www.ruanyifeng.com/blog/2011/01/json_in_php.html
以上就介绍了【PHP】JSON传值与PHP接收的几种情况,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

세션 고정 공격을 방지하는 효과적인 방법은 다음과 같습니다. 1. 사용자 로그인 한 후 세션 ID 재생; 2. 보안 세션 ID 생성 알고리즘을 사용하십시오. 3. 세션 시간 초과 메커니즘을 구현하십시오. 4. HTTPS를 사용한 세션 데이터를 암호화합니다. 이러한 조치는 세션 고정 공격에 직면 할 때 응용 프로그램이 파괴 할 수 없도록 할 수 있습니다.

서버 측 세션 스토리지가없는 토큰에 저장되는 토큰 기반 인증 시스템 인 JSONWEBTOKENS (JWT)를 사용하여 세션없는 인증 구현을 수행 할 수 있습니다. 1) JWT를 사용하여 토큰을 생성하고 검증하십시오. 2) HTTPS가 토큰이 가로 채지 못하도록하는 데 사용되도록, 3) 클라이언트 측의 토큰을 안전하게 저장, 4) 변조 방지를 방지하기 위해 서버 측의 토큰을 확인하기 위해 단기 접근 메커니즘 및 장기 상쾌한 토큰을 구현하십시오.

PHP 세션의 보안 위험에는 주로 세션 납치, 세션 고정, 세션 예측 및 세션 중독이 포함됩니다. 1. HTTPS를 사용하고 쿠키를 보호하여 세션 납치를 방지 할 수 있습니다. 2. 사용자가 로그인하기 전에 세션 ID를 재생하여 세션 고정을 피할 수 있습니다. 3. 세션 예측은 세션 ID의 무작위성과 예측 불가능 성을 보장해야합니다. 4. 세션 중독 데이터를 확인하고 필터링하여 세션 중독을 방지 할 수 있습니다.

PHP 세션을 파괴하려면 먼저 세션을 시작한 다음 데이터를 지우고 세션 파일을 파괴해야합니다. 1. 세션을 시작하려면 세션 _start ()를 사용하십시오. 2. Session_Unset ()을 사용하여 세션 데이터를 지우십시오. 3. 마지막으로 Session_Destroy ()를 사용하여 세션 파일을 파괴하여 데이터 보안 및 리소스 릴리스를 보장하십시오.

PHP의 기본 세션 저장 경로를 변경하는 방법은 무엇입니까? 다음 단계를 통해 달성 할 수 있습니다. session_save_path를 사용하십시오 ( '/var/www/sessions'); session_start (); PHP 스크립트에서 세션 저장 경로를 설정합니다. php.ini 파일에서 세션을 설정하여 세션 저장 경로를 전 세계적으로 변경하려면 세션을 설정하십시오. memcached 또는 redis를 사용하여 ini_set ( 'session.save_handler', 'memcached')과 같은 세션 데이터를 저장합니다. ini_set (

tomodifyDatainAphPessess, startSessionstession_start (), 그런 다음 $ _sessionToset, modify, orremovevariables.

배열은 PHP 세션에 저장할 수 있습니다. 1. 세션을 시작하고 session_start ()를 사용하십시오. 2. 배열을 만들고 $ _session에 저장하십시오. 3. $ _session을 통해 배열을 검색하십시오. 4. 세션 데이터를 최적화하여 성능을 향상시킵니다.

PHP 세션 쓰레기 수집은 만료 된 세션 데이터를 정리하기위한 확률 메커니즘을 통해 트리거됩니다. 1) 구성 파일에서 트리거 확률 및 세션 수명주기를 설정합니다. 2) CRON 작업을 사용하여 고재 응용 프로그램을 최적화 할 수 있습니다. 3) 데이터 손실을 피하기 위해 쓰레기 수집 빈도 및 성능의 균형을 맞춰야합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

WebStorm Mac 버전
유용한 JavaScript 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경
