编辑:这是我的网站日志中显示的内容xx.xx.xxx.xx - - [27/Jan/2012:17:42:24 -0500] "POST/dir/addData2.php HTTP/1.1" 200 - www.mywebsites.com "-" "Java/1.7.0" "-">
我在1&1托管我的网站,我希望页面blank.php
应该接受POST请求并将其上传到我的数据库。我认为我正确地发送了我的 POST,但不知何故我没有在我的网站上正确处理它。因为没有任何东西入到我的数据库中。 响应的内容长度为 0,但即使我发送带有字符串长度的标头,它也不会改变。另一种选择是主机不允许我进行远程发布请求(仍在等待回复(。
我从 Java 应用程序发送 post 请求,如下所示:
URL url = new URL("www.mywebsite.com/blank.php");
HttpURLConnection request = (HttpURLConnection)url.openConnection();
request.setRequestProperty("Content-type","application/x-www-form-urlencoded");
request.setRequestMethod("POST");
OutputStreamWriter post = new OutputStreamWriter(request.getOutputStream());
String data = URLEncoder.encode("account", "UTF-8") + "=" + URLEncoder.encode(message[0], "UTF-8");
data += "&" + URLEncoder.encode("message", "UTF-8") + "=" + URLEncoder.encode(message[2], "UTF-8");
data += "&" + URLEncoder.encode("type", "UTF-8") + "=" + URLEncoder.encode(message[0], "UTF-8");
post.write(data);
post.flush();
/*
/ String example
/account=103&message=Feller+1391.88+0&type=103
*/
来自服务器的响应是:
null=[HTTP/1.1 200 OK]
Date=[Fri, 27 Jan 2012 21:59:10 GMT]
Content-Length=[0]
Keep-Alive=[timeout=2, max=200]
Connection=[Keep-Alive]
Content-Type=[text/html]
Server=[Apache]
X-Powered-By=[PHP/5.2.17]
我的网页有这个基本的PHP代码(现在,稍后会改进/检查东西(
$link = mysql_connect($hostname, $username, $password);
$db_selected = mysql_select_db($database, $link);
$query = "INSERT INTO newData(account, message, type) VALUES('$_POST[account]', '$_POST[message]', '$_POST[type]')";
mysql_query($query) || die();
我想指出的是,我没有私人服务器,我以后可能会使用 http://hc.apache.org/httpcomponents-core-ga/examples.html。现在我只想从我的 Java 应用程序发送一个字符串,使用 PHP 接收它并插入到 MySQL 数据库。
是的,我确定您的ISP允许"发布"和"获取"HTTP服务器请求。
从表面上看,你的Java和PHP看起来都"OK"。
强烈建议:
1( 检查服务器上的 Apache 日志。
确保请求到达(可能已到达(。
检查错误(您的请求很可能没有错误 - 但您应该在 Apache 错误日志中看到一些内容。
2( 验证 PHP 是否正常工作。
用"phpinfo ((;"编写一个"hello world"页面是一个很好的方法。
3(验证MySQL是否正常工作。
编写一个"hello world"PHP页面来验证您可以1(连接,2(进行查询,以及3(在Web浏览器中回显查询是理想的。
4(验证您是否可以成功读取您认为从客户端获得的"$_POST[帐户]"值。
5(此时,您应该能够:
a( 让客户端与您的服务器通信
b( 读取 POST 请求并将其写入您的数据库
'希望这有帮助......并请回复您可能遇到的任何具体问题/问题。
您尚未告诉客户端代码这是一个 POST 请求。默认情况下,它可能会执行 GET。
url = new URL(targetURL);
connection = (HttpURLConnection)url.openConnection();
connection.setRequestMethod("POST");
看起来您没有在 HttpUrlConnection 上设置请求方法,默认值为 GET。你需要类似的东西
request.setRequestMethod("POST");
如果这不起作用,我会考虑从一开始就使用Apache HTTP客户端,它比Java的标准HTTP客户端API更容易使用。