我想知道是否有人能够帮助我。
我目前正在通过用户输入表单,XML和PHP的网站工作,用户将添加和保存谷歌地图信息到我的SQL数据库。
我已经成功地使用了Google网站上的一个例子,它解释了如何使用PHP和XML将用户定义的信息保存到数据库。
该示例使用$ GET方法,但根据我在网上阅读的信息,$ POST选项似乎是更好的方法。
但是,当我将编码更改为$ POST方法时,我可以在数据库上创建记录,但键入表单的值不会被复制到数据库中。我知道我可能会犯一个非常愚蠢的初学者错误,但我只是想知道是否有人能够告诉我我需要做些什么才能使其工作。
我已经在下面包含了减少版本的文件。
非常感谢
克里斯
HTML表单提交按钮
function savedata() {
var locationname = document.getElementById("locationname").value;
var returnedaddress = document.getElementById("returnedaddress").value;
var url = "phpfilename.php?locationname=" + locationname + "&returnedaddress=" + returnedaddress;
downloadUrl(url, function(data, responseCode) {
if (responseCode == 200 && data.length <= 1) {
}
});
}
function downloadUrl(url, callback) {
var request = window.ActiveXObject ?
new ActiveXObject('Microsoft.XMLHTTP') :
new XMLHttpRequest;
request.onreadystatechange = function() {
if (request.readyState == 4) {
request.onreadystatechange = doNothing;
callback(request.responseText, request.status);
}
};
request.open('POST', url, true);
request.send(null);
}
function doNothing() {}
</script>
HTML表单
<body>
<label><br />
</label>
<form name="searchforlocationformgeocode" id="searchforlocationformgeocode">
<div>
<label for="address">
<div align="center">
<p>Location Name</p>
<p>
<input name="locationname" type="text" id="locationname" size="80" />
</p>
</div>
<p align="left"><label>Returned Address</label> </p>
<div align="left">
<input name="returnedaddress" type="text" id="returnedaddress" size="100" />
</div>
PHP文件
<?php
require("phpfilename.php");
// Gets data from URL parameters
$locationname = $_POST['locationname'];
$address = $_POST['returnedaddress'];
// Opens a connection to a MySQL server
$connection = mysql_connect ("xxxxxxxx", $username, $password);
if (!$connection) {
die('Not connected : ' . mysql_error());
}
// Set the active MySQL database
$db_selected = mysql_select_db($database, $connection);
if (!$db_selected) {
die ('Can\'t use db : ' . mysql_error());
}
// Insert new row with user data
$query = sprintf("INSERT INTO tablename " .
" (locationname, address) " .
" VALUES ('%s', '%s', '%s');",
mysql_real_escape_string($locationname),
mysql_real_escape_string($address));
$result = mysql_query($query);
if (!$result) {
die('Invalid query: ' . mysql_error());
}
?>
这才有效,如果你正在使用AJAX来保存数据,您使用提交数据的方法。否则看看holodoc给出的答案。 – fromvega
嗨,非常感谢您看看我的帖子和相关信息,它可以帮助您更清楚地了解问题。 – IRHM