私はturn onボタンを押すと、lighton.jsonという名前のJSONファイルを開くturnon()関数を呼び出し、そこに{light ":" "}しかし、それは私のために働かないし、私は理由を知らない。誰か助けてくれますか?AJAXを使用してJSONファイルを編集
<?php
$light = $_GET['light'];
$file = fopen("light.json", "w") or die("can't open file");
if($light == "on") {
fwrite($file, '{"light": "on"}');
}
else if ($light == "off") {
fwrite($file, '{"light": "off"}');
}
?>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>LED for ESP8266</title>
<script src="https://code.jquery.com/jquery-2.1.4.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet">
<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css">
</head>
<body>
<div class="row" style="margin-top: 20px;">
<div class="col-md-8 col-md-offset-2">
<form>
<input type="button" id="StartButton" value="Turn On" onClick="turnOn()">
</form>
<!--<button onclick="turnOn()">Turn On</button>
<button onclick="turnOff()">Turn Off</button>-->
<div class="light-status well" style="margin-top: 5px; text-align:center">
<script type="text/javascript">
function turnOn() {
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8",
url: "http://192.168.1.108/test/light.json",
data: {"light": "on"},
dataType: "json",
success: function (data) {
alert(data);
},
error: function (result) {
alert("Error");
}
});
}
</script>
</div>
</div>
</div>
</body>
</html>
ありがとうございます!
「動作しません」とはどういう意味ですか?エラーが出ますか?もしそうなら、どのようなエラー? –
'url:" http://192.168.1.108/test/light.json "' - JSONファイルのURLにデータを投稿するだけで、自動的に何かが起こるとは限りません。サーバー側のスクリプトにデータを投稿する必要があります。 PHPファイルの先頭にコードを表示すると、おそらく投稿したいアドレスになります。しかし、ケニーの答えの反対をしたいと思うでしょう.GETを使うと、あなたのスクリプトは_every_リクエストでファイルに書き込むので、すでにページを呼び出すときです。代わりにPOSTを使用して、まずあなたのスクリプトが実際に期待するパラメータが存在するかどうかを確認するために、まずisset/emptyを調べてください。 – CBroe