2011-07-23 61 views
0

我想知道是否有人能够帮助我。

我目前正在通过用户输入表单,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>&nbsp;</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()); 
} 

?> 

回答

1

您正在使用查询字符串传递值,以获取它们您需要使用$ _GET。

var url = "phpfilename.php?locationname=" + locationname + "&returnedaddress=" +  returnedaddress; 

要使用$ _POST,而不是添加的编码的名称/值对的URL的末尾,通过request.send发送它们()方法:

request.send("locationname=" + locationname + "&returnedaddress=" + returnedaddress); 
+0

这才有效,如果你正在使用AJAX来保存数据,您使用提交数据的方法。否则看看holodoc给出的答案。 – fromvega

+0

嗨,非常感谢您看看我的帖子和相关信息,它可以帮助您更清楚地了解问题。 – IRHM

1

的一般规则拇指是,如果你的目标页面应该只是检索一些信息使用GET就好了,但是如果你的数据应该对数据库进行任何更改等,你应该总是使用POST。

顺便说一句,你的表单标签必须包含在这种情况下method="post"

<form name="searchforlocationformgeocode" id="searchforlocationformgeocode" method="post"> 
+0

非常感谢您的信息,非常有帮助! – IRHM