我有一个重定向一个img src属性一个PHP页面nginx的重写规则。在这个php页面中,我试图做一个GET请求,它在成功时向同一个页面发出POST请求,并将GET请求返回的数据作为数据发送。为什么PHP脚本中的$ _POST数据为空?如果我在PHP脚本中对$name = "http://path/to/my/img.png"
进行了硬编码,则图像正确呈现。
<?php
ini_set('display_errors',1);
ini_set('display_startup_errors',1);
error_reporting(-1);
var_dump($_REQUEST);
//if(isset($_POST['val'])) {
// open the file in a binary mode
$name = $_POST['val']; // ALWAYS EMPTY
$fp = fopen($name, 'rb');
// send the right headers
header("Content-Type: image/png");
header("Content-Length: " . filesize($name));
// dump the picture and stop the script
//echo fpassthru($fp);
header("Location: $name");
exit;
//}
?>
<html>
<head>
<script type='text/javascript' src='/steal/steal.js'></script>
<script type="text/javascript" src="/plugins/jquery/json2.js"></script>
<script type="text/javascript">
steal('jquery/dom/fixture').then(function(){
$.fixture("GET /event/{code}", function(original, settings, headers){
return [200, "success", { "img_url":"http://path/to/my/img.png" }, {} ]
})
var strObj = <?php echo json_encode($_REQUEST); ?>;
var str = strObj.q;
var eventCode = str.split('/')[1];
$.ajax({
url: "/event/"+eventCode,
success: function(data) {
var imgUrl = data.img_url
$.ajax({
type: 'POST',
contentType: 'json',
data: {val:imgUrl},
success: function(data){
console.log(data);
},
error: function(jqXHR, textStatus, errorThrown){
console.log(textStatus);
}
});
}
});
});
</script>
</head>
<body>
</body>
</html>
好起来。你正在尝试将图像点的src指向这个php页面,在你正在输出javascript的页面(据称用户浏览器运行)中,然后将POST请求发送到与它们相同的url刚刚进入GET? – castis
这是用于电子邮件跟踪。基本上,用户将收到一封电子邮件,并在打开该电子邮件时,img src属性向uri发出请求,然后将其重写为php脚本。 php脚本接收$ _REQUEST数据 - 包含与用户绑定的一些id,使用该id发出GET请求,成功时返回一个url。从这里开始,url被用作POST请求的数据到相同的php页面,在那里它将被base64编码并作为img src属性返回。这听起来也很复杂,所以我愿意提供建议。 – neridaj