【问题标题】:Android app can't insert data into MySQL DBAndroid 应用程序无法将数据插入 MySQL 数据库
【发布时间】:2016-04-17 12:52:43
【问题描述】:

我对 Android 编码相当陌生,我正在尝试创建将一些信息插入我的 MySQL 数据库的应用程序。我在网上找到了很多教程和技巧,并创建了 lite 应用程序来尝试程序。一切编译正常,应用程序运行,似乎成功发送数据。但实际上,我的表中并没有出现任何数据。
这是我的 PHP 代码 android_add.php:

<?php
$con = mysqli_connect(localhost, user, psswd, name);   //those works
mysqli_set_charset($con, "utf8");     //working with special symbols

$name = $_POST['name'];       //get name & author from App
$author = $_POST['author'];

$sql = "insert into kniha_test (k_autor_pr,k_nazev) values ('$name','$address')";                
if(mysqli_query($con,$sql)){
    echo 'success';
} else {
    echo 'failure';
}
mysqli_close($con);
?>

这是我的 MainActivity.java:

import android.content.ContentValues;
import android.os.AsyncTask;
import android.provider.Settings;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;


import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.ProtocolException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {

    private EditText editTextName;
    private EditText editTextAuthor;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        editTextName = (EditText) findViewById(R.id.editTextName);
        editTextAuthor = (EditText) findViewById(R.id.editTextAuthor);
    }

    public void insert (View view){
        String name = editTextName.getText().toString();
        String author = editTextAuthor.getText().toString();

        insertToDatabase(name,author);
    }

    protected void insertToDatabase(String name, String author){
        class SendPostReqAsyncTask extends AsyncTask<String, Void, String> {


            String name;
            String author;
            public void saveNameAut(String name, String author){
                this.name = name;
                this.author = author;
                name = editTextName.getText().toString();
                author = editTextAuthor.getText().toString();
            }

            @Override
            protected String doInBackground(String... params){
                String paramName = params[0];
                String paramAuthor = params[1];



                ContentValues values = new ContentValues();
                values.put("name", this.name);
                values.put("author", this.author);

                String addUrl = "http://glaserproject.com/knihovna_kyber/android/android_add.php";

                try {URL url = new URL(addUrl);
                HttpURLConnection conn = (HttpURLConnection) url.openConnection();
                conn.setRequestMethod("POST");

                System.out.println("Response Code: " + conn.getResponseCode());

                } catch (IOException e){};

                return "Succes";
            }

            @Override
            protected void onPostExecute(String result){
                super.onPostExecute(result);

                Toast.makeText(getApplicationContext(), result, Toast.LENGTH_LONG).show();
                TextView textViewResult = (TextView) findViewById(R.id.textViewResult);
                textViewResult.setText("inserted");
            }
        }
        SendPostReqAsyncTask sendPostReqAsyncTask = new SendPostReqAsyncTask();
        sendPostReqAsyncTask.execute(name, author);
    }

}

正如我所说,我只是初学者,所以可能有一些非常愚蠢的东西,但我不知道是什么。并且可能会有一些来自不同尝试的垃圾线。 PHP 代码应该没问题,我使用几乎相同的方式从 HTML 插入,所以我猜,我的 Java 代码有问题。
我将非常感谢您的建议/回复。
谢谢!

PS:我得到的响应码是 200。

【问题讨论】:

  • INSERT 语句中的$address 是否应该是$author
  • php 代码不正确。我得到一个 200 状态,但它返回字符串“失败”。我相信您的意思是在查询中输入 $author 而不是 $address
  • 您的 PHP 错误日志中是否出现异常?您也可以尝试surrounding the code in a try-catch 来检测mysqli_* 语句引发的任何异常并查看问题可能是什么
  • 我会先检查 PHP 脚本。将您的查询变量更改为 $_GET,然后转到您的浏览器 domain.com/script.php?name=name&author=author - 您的数据库是否已填充?
  • 我使用Postman检查了php脚本,这对于使用这样的php脚本调试错误非常有帮助。

标签: java php android mysql mysqli


【解决方案1】:

您正在通过 AsyncTask 发送空值 您是否打印了要发送的值
试试这个

protected void insertToDatabase(String name, String author){
    class SendPostReqAsyncTask extends AsyncTask<String, Void, String> {


        String cName=name;
        String cAuthor=author;


        @Override
        protected String doInBackground(String... params){

            ContentValues values = new ContentValues();
            values.put("name", cName);
            values.put("author", cAuthor);

            String addUrl = "http://glaserproject.com/knihovna_kyber/android/android_add.php";

            try {URL url = new URL(addUrl);
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("POST");

            System.out.println("Response Code: " + conn.getResponseCode());

            } catch (IOException e){};

            return "Succes";
        }

        @Override
        protected void onPostExecute(String result){
            super.onPostExecute(result);

            Toast.makeText(getApplicationContext(), result, Toast.LENGTH_LONG).show();
            TextView textViewResult = (TextView) findViewById(R.id.textViewResult);
            textViewResult.setText("inserted");
        }
    }
    SendPostReqAsyncTask sendPostReqAsyncTask = new SendPostReqAsyncTask();
    sendPostReqAsyncTask.execute(name, author);
}

再试一次,如果它解决了你的问题,请告诉我......

【讨论】:

  • 我在 PHP 中解决了一个问题,但即使使用您的代码,我也会发送空白字符串(将空值输入 DB)。奇怪的是,即使我在将它们设置为内容值之前定义了值,它仍然无法正常工作。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-08-08
  • 1970-01-01
  • 2021-12-23
  • 1970-01-01
相关资源
最近更新 更多