이 글은 csrf-token 검증을 통한 php 컬의 시뮬레이션 제출 방법에 대한 자세한 설명을 주로 소개하고 있습니다. 편집자가 꽤 좋다고 생각해서 지금 공유하고 참고용으로 올려드리겠습니다. 편집기를 따라 살펴보겠습니다
일반적으로 보안상의 이유로 CSRF 공격을 방지하기 위해 임의의 토큰 값이 양식에 추가됩니다.
토큰 확인을 통해 웹사이트 제출을 시뮬레이션하는 것은 실제로 어렵지 않습니다.取1. 정기적으로 토큰
2을 받으세요.form.php
│ form.php –需要模拟的表单 │ getForm.php – 模拟提交程序 │ post.php –表单验证程序 │ └─cookie – cookie存放目录
post.php
<?php $cookie_file = './cookie/'.time().'.cookie'; $str = getResponse('http://a.curl.com:81/form.php',[],$cookie_file); setcookie("PHPSESSID", "vc0heoa6lfsi3gger54pkns152"); preg_match('/<input name="token" type="hidden" value="(.*)"/U', $str, $match); $post['token'] = $match[1]; $post['name'] = '3333333'; $post['password'] = '12121213'; print_r(getResponse('http://a.curl.com:81/post.php', $post, $cookie_file)); function getResponse($url, $data=[], $cookie_file='', $timeout = 3) { if(empty($cookie_file)) { $cookie_file = '.cookie'; } $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_REFERER, "https://www.baidu.com"); //构造来路 curl_setopt($ch, CURLOPT_USERAGENT,"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.59 Safari/537.36"); if(!empty($data)) { curl_setopt($ch, CURLOPT_POST, true); curl_setopt($ch, CURLOPT_POSTFIELDS, $data); } curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file);// 取cookie的参数是 curl_setopt ($ch, CURLOPT_COOKIEFILE, $cookie_file); //发送cookie curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout); try { $handles = curl_exec($ch); curl_close($ch); return $handles; } catch (Exception $e) { echo 'Caught exception: ', $e->getMessage(), "\n"; } unlink($cookie_file); }
위 내용이 모든 사람에게 도움이 되기를 바랍니다. 공부하고, 모두가 PHP 중국어 웹사이트를 지지해주기를 바랍니다.
당신이 관심을 가질 만한 기사:
PHP 반복자와 반복 구현 및 사용 분석 PHP 기술PHP 작업 추가, 삭제, 수정 및 확인 기능의 MongoDB 구현 PHP 기술
PHP Redis 운용 공통 스킬 요약 PHP Skill위 내용은 csrf-token 검증 시뮬레이션 제출 방법을 사용한 php 컬에 대한 자세한 설명 php 예제의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!