- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将数据从 Android 应用程序发送到 MySQL 数据库,它工作正常,但只有一个用户名字段不起作用。基本上,应用程序将问题数据发送到数据库,只有一个用户名字段保留为空,其他工作正常。
代码如下:这是我的 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/
目前我正在构建相当大的网络系统,我需要强大的 SQL 数据库解决方案。我选择 Mysql 而不是 Postgres,因为一些任务需要只读(MyISAM 引擎)而其他任务需要大量写入(InnoDB)。
我在 mysql 中使用如下命令。当它显示表格数据时,它被格式化为一个非常干净的表格,间距均匀且 |作为列分隔符。 SELECT * FROM TABLE_NAME; 当我从 CLI 运行命令时,如下
我知道这个问题之前已经被问过好几次了,我已经解决了很多问题,但到目前为止没有任何效果。 MySQL 试图将自身安装到的目录 (usr/local/mysql) 肯定有问题。关于我的错误的奇怪之处在于我
以下是我的 SQL 数据结构,我正在尝试如下两个查询: Select Wrk_ID, Wrk_LastName, Skill_Desc from Worker, Skill where
我们有一个本地 mysql 服务器(不在公共(public)域上),并希望将该服务器复制到我们拥有的 google 云 sql 实例。我的问题是:1.这可能吗?2.我们的本地服务器只能在本地网络上访问
我有一个表(test_table),其中一些字段值(例如字段 A、B 和 C)是从外部应用程序插入的,还有一个字段(字段 D),我想从现有表(store_table)插入其值,但在插入前者(A、B 和
我想创建一个 AWS RDS 实例,然后使用 terraform 管理数据库用户。因此,首先,我创建了一个 RDS 实例,然后使用创建的 RDS 实例初始化 mysql 提供程序,以进一步将其用于用户
当用户在我的网站上注册时,他们会在我的一个数据库中创建自己的表格。该表存储用户发布的所有帖子。我还想做的是也为他们生成自己的 MySql 用户——该用户仅有权从他们的表中读取、写入和删除。 创建它应该
我有一个关于 ColdFusion 和 Mysql 的问题。我有两个表:PRODUCT 和 PRODUCT_CAT。我想列出包含一些标记为:IS_EXTRANET=1 的特殊产品的类别。所以我写了这个
我想获取 recipes_id 列的值,以获取包含 ingredient_id 的 2,17 和 26 条目的值。 假设 ingredient_id 2 丢失则不获取记录。 我已经尝试过 IN 运算符
在 Ubuntu 中,我通常安装两者,但 MySQL 的客户端和服务器之间有什么区别。 作为奖励,当一个新语句提到它需要 MySQL 5.x 时,它是指客户端、服务器还是两者兼而有之。例如这个链接ht
我重新访问了我的数据库并注意到我有一些 INT 类型的主键。 这还不够独特,所以我想我会有一个指导。 我来自微软 sql 背景,在 ssms 中你可以 选择类型为“uniqeidentifier”并自
我的系统上有 MySQL,我正在尝试确定它是 Oracle MySQL 还是 MySQL。 Oracle MySQL 有区别吗: http://www.oracle.com/us/products/m
我是在生产 MySQL 中运行的应用程序的新维护者。之前的维护者已经离开,留下的文档很少,而且联系不上了。 我面临的问题是执行以下请求大约需要 10 秒: SELECT COUNT(*) FROM `
我有两个位于不同机器上的 MySQL 数据库。我想自动将数据从一台服务器传输到另一台服务器。比方说,我希望每天早上 4:00 进行数据传输。 可以吗?是否有任何 MySQL 内置功能可以让我们做到这一
有什么方法可以使用 jdbc 查询位于 mysql 根目录之外的目录中的 mysql 表,还是必须将它们移动到 mysql 根目录内的数据库文件夹中?我在 Google 上搜索时没有找到任何东西。 最
我在 mysql 数据库中有两个表。成员和 ClassNumbers。两个表都有一个付费年份字段,都有一个代码字段。我想用代码数字表中的值更新成员表中的付费年份,其中成员中的代码与 ClassNumb
情况:我有 2 台服务器,其中一台当前托管一个实时 WordPress 站点,我希望能够将该站点转移到另一台服务器,以防第一台服务器出现故障。传输源文件很容易;传输数据库是我需要弄清楚如何做的。两台服
Phpmyadmin 有一个功能是“复制数据库到”..有没有mysql查询来写这个函数?类似于将 db A 复制到新的 db B。 最佳答案 首先创建复制数据库: CREATE DATABASE du
我有一个使用 mySQL 作为后端的库存软件。我已经在我的计算机上对其进行了测试,并且运行良好。 当我在计算机上安装我的软件时,我必须执行以下步骤: 安装 mySQL 服务器 将用户名指定为“root
我是一名优秀的程序员,十分优秀!