0

我一直在尝试让我的 Android 应用程序将数据发布到 PHP 文件,然后将该数据写入数据库,但是我遇到了一些麻烦。

我收到此错误,但它不是强制关闭或任何东西。

日志输出:

08-13 20:29:42.859: I/postData(11950): HTTP/1.1 200 OK
08-13 20:29:42.859: E/log_tag(11950): Error in http connectionjava.lang.IllegalStateException: Content has been consumed

这是有问题的代码,它正在做我所有的 HTTP POST 工作,即 android 方面的事情:

SubmitWord task = new SubmitWord(); 
task.execute(new String[] { "http://www.hanged.comli.com/main.php" });

上面的代码调用了这个异步任务:

          private class SubmitWord extends AsyncTask<String, Void, String> 
    {
        @Override
        protected String doInBackground(String... urls) 
        {
          String response = "";
          try
          {
            URL = urls[0];
            ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(4);
            nameValuePairs.add(new BasicNameValuePair("victim",myId));
            nameValuePairs.add(new BasicNameValuePair("rival",newname));
            nameValuePairs.add(new BasicNameValuePair("word","HELLOHOMO"));
            nameValuePairs.add(new BasicNameValuePair("won","0"));

              HttpClient httpclient = new DefaultHttpClient();
              HttpPost httppost = new      
              HttpPost(URL);
              httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));

              HttpResponse execute = httpclient.execute(httppost);
              HttpEntity entity = execute.getEntity();
              InputStream is = entity.getContent();

             Log.i("postData", execute.getStatusLine().toString());
             //HttpEntity entity = response.getEntity();
              is = entity.getContent();
          }
          catch(Exception e)
          {
                  Log.e("log_tag", "Error in http connection"+e.toString());
          }
                return response;
            } 

        @Override
        protected void onPostExecute(String result) 
        {
          mText.setText("DONE");
        }

      }

这是PHP方面的事情:

<?php

 /// REMOVED DATABASE DETAILS

$connect = mysql_connect("$mysql_host", "$mysql_user", "$mysql_password")or die("cannot   connect");
 mysql_select_db("$mysql_database", $connect)or die("cannot select DB");

session_start();

$victim = $_POST['victim'];
$rival = $_POST['rival'];
$word = $_POST['word'];
$won = $_POST['won'];

mysql_query("INSERT INTO currentgames (victim, rival, wordguess, won) VALUES('$victim',       '$rival', '$word', '$won'))");

我很确定这只是我弄错的 Java/Android 部分,但我一生都无法弄清楚我做错了什么,我尝试了各种不同的 POSTING 数据方法并阅读了使用 HTTPOST 的教程数量。也许我只是没有正确理解。

4

1 回答 1

2

罪魁祸首是你打getContent();了两次电话。

根据javadoc

返回实体的内容流。可重复实体应为每次调用此方法创建一个新的 InputStream 实例,因此可以多次使用。不可重复的实体应返回相同的 InputStream 实例,因此不得多次使用。

于 2012-08-13T20:39:10.950 回答