【发布时间】: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