通过Ajax POST和PHP将数据保存到文件


Save Data to File via Ajax POST and PHP

我只想在服务器上的一个文件中保存一些JSON(用Javascript生成)。但我甚至无法使用一个简单的字符串:

HTML文件:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
<style>
#test{
padding:20px 50px;
background:#ccc;
color:#000;
}
</style>
<script>
$(function(){
$('#test').click(function(){
    $.ajax({
        url: "page.php",
        data: {"foo": "bar"},
        processData: false,
        contentType: 'application/json'
    });
});
});
</script>
</head>
<body>
<div id="test">
KLICK
</div>
</body>
</html>

php文件是这样的:

<?php
$myFile = "testFile.txt";
$fh = fopen($myFile, 'w');
fwrite($fh,$_POST['data']);
fwrite($fh,$_POST['foo']);
fwrite($fh,$_POST["foo"]);
fwrite($fh,$_POST[foo]);
fclose($fh);

什么都没用。我也试过

$.ajax({
    var datatosend="foo bar";
    url: "page.php",
    data: datatosend,
    processData: false
    });

我不知道出了什么问题。txt文件在单击html文件中的div之后就会出现。但文件中没有任何内容。如果我只是将$_POST写入文本文件,则该文件包含文本"数组",这意味着$_POST具有一些内容。

这里几乎没有什么问题。检查您要写入的目录的权限。还要确保您的ajax调用使用POST方法。

$.ajax({
  url: "page.php",
  type : 'POST',
  ...
}); 

正如jQuery文档中所述,type参数设置请求类型POST或GET。

要发出的请求类型("POST"或"GET"),默认为"GET"。


另一件需要考虑的事情是,您实际上并不是在编写JSON数据。数据以该格式发送,但当它到达$_POST变量时,它已被转换为数组。您应该尝试将PHP数组写入文件-

$fh = fopen($myFile, 'w');
fwrite($fh,'<?php $arr='.var_export($_POST['data'],true).' ?>');
fclose($fh);

这应该会给出一个类似的文件-

<?php
  $arr = array(
    'foo'=>'bar'
  )
?>

正如您所看到的,var_export()函数返回变量的可解析版本。

  • var_export()

var_export--输出或返回变量的可解析字符串表示

您需要进行POST调用,请参阅以下内容:

$('#test').click(function(){
    $.ajax({
        url: "page.php",
        type : 'post', 
        data: {"foo": "bar"},
        processData: false,
        contentType: 'application/json'
    });
});

默认情况下,所有$.ajax()请求都使用GET方法发送,而不是POST。您需要将类型指定为"POST":

$.ajax({
    var datatosend="foo bar";
    url: "page.php",
    type: 'post',
    data: datatosend,
    processData: false
    });

来自文件:

type-字符串

默认值:"GET"

要发出的请求类型("POST"或"GET"),默认为"GET"。注:也可以使用其他HTTP请求方法,如PUT和DELETE这里,但并非所有浏览器都支持它们。

可能是

    $.ajax({
    url: "page.php",
    type: "POST", // add this
    data: {"foo": "bar"},
    processData: false,
    contentType: 'application/json'
});

在PHP中使用$_REQUEST而不是$_POST