gpt4 book ai didi

php - 尝试将数据从 android 应用程序发送到 mysql 数据库,一个字段不起作用

转载 作者:行者123 更新时间:2023-11-29 21:08:54 25 4
gpt4 key购买 nike

我正在尝试将数据从 Android 应用程序发送到 MySQL 数据库,它工作正常,但只有一个用户名字段不起作用。基本上,应用程序将问题数据发送到数据库,只有一个用户名字段保留为空,其他工作正常。

数据库截图: enter image description here

enter image description here

代码如下:这是我的 MainActivity 正在尝试发送

    package miniandroid.com.activities;

import android.app.Activity;
import android.app.AlertDialog;
import android.app.Dialog;
import android.app.NotificationManager;
import android.app.ProgressDialog;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import android.widget.RadioGroup.OnCheckedChangeListener;
import android.widget.TextView;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.URL;
import java.net.URLConnection;
import java.net.URLEncoder;

import miniandroid.com.R;


public class MainActivity extends Activity {
private TextView ques3s1;
private EditText edit3s1, edit1, edit2, edit4;
private RadioGroup radioSexGroup;
private RadioButton radioSexButton1, radioSexButton3;
private ProgressDialog progress;
private Dialog dialog;

private static final int MY_NOTIFICATION_ID = 11;
String ns = Context.NOTIFICATION_SERVICE;
NotificationManager mNotificationManager;

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.notification);

mNotificationManager = (NotificationManager) getSystemService(ns);
mNotificationManager.cancel(MY_NOTIFICATION_ID);
radioSexButton1 = (RadioButton) findViewById(R.id.radioButton);
radioSexButton3 = (RadioButton) findViewById(R.id.radioButton3);
edit1 = (EditText) findViewById(R.id.rg_qus1);
edit2 = (EditText) findViewById(R.id.rg_qus2);
edit4 = (EditText) findViewById(R.id.rg_qus4);
ques3s1 = (TextView) findViewById(R.id.qus3s1);
edit3s1 = (EditText) findViewById(R.id.rg_qus3s1);
ques3s1.setVisibility(View.GONE);
edit3s1.setVisibility(View.GONE);
SharedPreferences prefs = getSharedPreferences("emood_veriif", MODE_PRIVATE);
String user = prefs.getString("Username", "");
setTitle("sMood " + user);
progress = new ProgressDialog(this);
progress.setMessage("Loading...");
dialog = new AlertDialog.Builder(this).create();

radioSexGroup = (RadioGroup) findViewById(R.id.radioGroup);
radioSexGroup.setOnCheckedChangeListener(new OnCheckedChangeListener() {
@Override
public void onCheckedChanged(RadioGroup group, int checkedId) {
SharedPreferences prefs = getSharedPreferences("emood_veriif", MODE_PRIVATE);
String question3s1 = prefs.getString("Question3s1", "");
String question3s2 = prefs.getString("Question3s2", "");

if (radioSexButton1.isChecked()) {
ques3s1.setText(question3s1);
ques3s1.setVisibility(View.VISIBLE);
edit3s1.setVisibility(View.VISIBLE);

} else if (radioSexButton3.isChecked()) {
ques3s1.setText(question3s2);
ques3s1.setVisibility(View.VISIBLE);
edit3s1.setVisibility(View.VISIBLE);
} else {
ques3s1.setVisibility(View.GONE);
edit3s1.setVisibility(View.GONE);
}

}
});

Button continues = (Button) findViewById(R.id.btn_contsubmit);
continues.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
SharedPreferences prefs = getSharedPreferences("emood_veriif", MODE_PRIVATE);
String question1 = prefs.getString("Question1", "");
String question2 = prefs.getString("Question2", "");
String question3 = prefs.getString("Question3", "");
String question4 = prefs.getString("Question4", "");
String question3s1 = prefs.getString("Question3s1", "");
String question3s2 = prefs.getString("Question3s2", "");
String user = prefs.getString("Username", "");
String ans1 = edit1.getText().toString();
String ans2 = edit2.getText().toString();
String ans3 = edit3s1.getText().toString();
String ans4 = edit4.getText().toString();
String radioanswer;
String question3s;
if (radioSexButton1.isChecked()) {
radioanswer = "Happy";
question3s = question3s1;
} else if (radioSexButton3.isChecked()) {
radioanswer = "Sad";
question3s = question3s2;
} else {
radioanswer = "Normal";
question3s = "";
}

PostAnswerTask task = new PostAnswerTask();
task.execute(user, question1, ans1, question2, ans2, question3, radioanswer, question3s, ans3, question4, ans4);
}
});

}


class PostAnswerTask extends AsyncTask<String, Void, String> {
protected void onPreExecute() {
progress.show();

}

@Override
protected String doInBackground(String... arg0) {
try {
String user = arg0[0];
String question1 = arg0[1];
String ans1 = arg0[2];
String question2 = arg0[3];
String ans2 = arg0[4];
String question3 = arg0[5];
String radioanswer = arg0[6];
String question3s = arg0[7];
String ans3 = arg0[8];
String question4 = arg0[9];
String ans4 = arg0[10];

String link = "http://miniandroid.com/answered.php";
String data = URLEncoder.encode("user", "UTF-8") + "=" + URLEncoder.encode(user, "UTF-8");
data += "&" + URLEncoder.encode("question1", "UTF-8") + "=" + URLEncoder.encode(question1, "UTF-8");
data += "&" + URLEncoder.encode("ans1", "UTF-8") + "=" + URLEncoder.encode(ans1, "UTF-8");
data += "&" + URLEncoder.encode("question2", "UTF-8") + "=" + URLEncoder.encode(question2, "UTF-8");
data += "&" + URLEncoder.encode("ans2", "UTF-8") + "=" + URLEncoder.encode(ans2, "UTF-8");
data += "&" + URLEncoder.encode("question3", "UTF-8") + "=" + URLEncoder.encode(question3, "UTF-8");
data += "&" + URLEncoder.encode("radioanswer", "UTF-8") + "=" + URLEncoder.encode(radioanswer, "UTF-8");
data += "&" + URLEncoder.encode("question3s", "UTF-8") + "=" + URLEncoder.encode(question3s, "UTF-8");
data += "&" + URLEncoder.encode("ans3", "UTF-8") + "=" + URLEncoder.encode(ans3, "UTF-8");
data += "&" + URLEncoder.encode("question4", "UTF-8") + "=" + URLEncoder.encode(question4, "UTF-8");
data += "&" + URLEncoder.encode("ans4", "UTF-8") + "=" + URLEncoder.encode(ans4, "UTF-8");
URL url = new URL(link);
URLConnection conn = url.openConnection();
conn.setDoOutput(true);
OutputStreamWriter wr = new OutputStreamWriter
(conn.getOutputStream());
wr.write(data);
wr.flush();
BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));
StringBuilder sb = new StringBuilder();
String line = null;
// Read Server Response
while ((line = reader.readLine()) != null) {
sb.append(line);
break;
}

return sb.toString();
} catch (Exception e) {
return new String("Unable to connect. Please contact your network provider.");
}
}


@Override
protected void onPostExecute(String result) {

if (result.equals("Done")) {
progress.dismiss();
Intent intent = new Intent(MainActivity.this, AnsweredActivity.class);
startActivity(intent);
finish();
} else {
progress.dismiss();
((AlertDialog) dialog).setMessage(result);
dialog.show();
}


}
}


}

这是托管的 php 文件。

<?php
$db=new mysqli('fdb12.freehostingeu.com',
'2099457_app',
'kimPossible123',
'2099457_app');

$stmt=$db->stmt_init();
$user=$_POST['user'];
$question1=$_POST['question1'];
$ans1=$_POST['ans1'];
$question2=$_POST['question2'];
$ans2=$_POST['ans2'];
$question3=$_POST['question3'];
$radioanswer=$_POST['radioanswer'];
$question3s=$_POST['question3s'];
$ans3=$_POST['ans3'];
$question4=$_POST['question4'];
$ans4=$_POST['ans4'];

if($stmt->prepare("INSERT INTO question_answer
(`Username`,`Question1`,`Answer1`,
`Question2`,`Answer2`,
`Question3`,`Answer3`,
`Question3_Sub`,`Answer3_Sub`,
`Question4`,`Answer4`)
VALUES (?,?,?,?,?,?,?,?,?,?,?)")) {
$stmt->bind_param('sssssssssss',
$user,$question1,$ans1,
$question2,$ans2,
$question3,$radioanswer,
$question3s,$ans3,
$question4,$ans4);
$result=$stmt->execute();
}
if ($result) {
echo "Done";
} else{
echo "An Error Occured";
}
?>

在我的注册文件中,一切正常。数据库为所有字段设置了 varchar 数据类型。我似乎无法弄清楚问题是什么。索引似乎很好,问题也进入了正确的领域。

非常感谢任何帮助。问候

最佳答案

作为警告,在插入变量之前,我会在变量上使用 mysqli_real_escape_string 以防止 SQL 注入(inject)和查询时出错。

$user=$db->real_escape_string($_POST['user']);
$question1=$db->real_escape_string($_POST['question1']);
$ans1=$db->real_escape_string($_POST['ans1']);
$question2=$db->real_escape_string($_POST['question2']);
$ans2=$db->real_escape_string($_POST['ans2']);
$question3=$db->real_escape_string($_POST['question3']);
$radioanswer=$db->real_escape_string($_POST['radioanswer']);
$question3s=$db->real_escape_string($_POST['question3s']);
$ans3=$db->real_escape_string($_POST['ans3']);
$question4=$db->real_escape_string($_POST['question4']);
$ans4=$db->real_escape_string($_POST['ans4']);

// then echo out the $user to see if it was passed
echo $user;

然后我会尝试打印用户名以查看它是否正确传递给脚本。如果没有打印任何内容,则错误出现在 MainActivity 代码中的某个位置。可能是在准备帖子的时候。

关于php - 尝试将数据从 android 应用程序发送到 mysql 数据库,一个字段不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36581110/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com