利用fsocket模拟GET和POST请求

本文介绍了一种使用PHP中的fsocket函数模拟HTTP GET和POST请求的方法,并提供了完整的示例代码。通过这些代码,可以更好地理解如何手动构建HTTP请求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近看了脚本之家上的一篇文章:php模拟post行为代码总结(POST方式不是绝对安全),讲述的主要是关于用各种方法模拟GET和POST请求的问题。其中有一段是关于用fsocket模拟的,感觉其中有一些错误。查了下网上其他的文章,几乎都是复制+粘贴上去的。本人修改后的代码如下,如有不足或者错误的地方,希望各位能提出建议和意见。

模拟发出请求的页面index.php

<?php 
//fsocket模拟get提交 
$gurl = "http://localhost/php/t.php?uu=gggggg"; 
//print_r(parse_url($gurl)); 
echo "以下是GET方式的响应内容:<br>";
sock_get($gurl);  
function sock_get($url) 
{ 
$info = parse_url($url); 
$fp = fsockopen($info["host"], 80, $errno, $errstr, 3); 
$head = "GET ".$info['path']."?".$info["query"]." HTTP/1.0\r\n"; 
$head .= "Host: ".$info['host']."\r\n"; 
$head .= "\r\n"; 
$write = fputs($fp, $head); 
while (!feof($fp)) 
{ 
$line = fgets($fp);
echo $line."<br>"; 
} 
} 



//fsocket模拟post提交
$purl = "http://localhost/php/t.php";
echo "以下是POST方式的响应内容:<br>";
sock_post($purl,"uu=rrrrrrrrrrrr&&kk=mmmmmm");  
function sock_post($url, $query) 
{ 
$info = parse_url($url); 
$fp = fsockopen($info["host"], 80, $errno, $errstr, 3); 
$head = "POST ".$info['path']." HTTP/1.0\r\n"; 
$head .= "Host: ".$info['host']."\r\n"; 
$head .= "Referer: http://".$info['host'].$info['path']."\r\n"; 
$head .= "Content-type: application/x-www-form-urlencoded\r\n"; 
$head .= "Content-Length: ".strlen(trim($query))."\r\n"; 
$head .= "\r\n"; 
$head .= trim($query); 
$write = fputs($fp, $head); 
while (!feof($fp)) 
{ 
$line = fgets($fp); 
echo $line."<br>"; 
} 
} 
?> 

请求的响应页面t.php

<?php
if(isset($_GET['uu'])){
	echo '<font color="red">t.php中$_GET["uu"]的值是:'.$_GET['uu']."</font><br>";
}
if(isset($_POST['uu'])){
	echo '<font color="red">t.php中$_POST的值是:</font><br>';
	print_r($_POST);
}	
?>

以下为运行结果:



以下为Firebug的查看结果:


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值