我正在尝试将多个(1-50)条目从Android应用程序插入外部Mysql数据库。我完全有一个PHP脚本可用于单个INSERT查询。但到目前为止,我还没有为一系列条目做这项工作,很可能是由于我对PHP的理解有限。
Android代码:
List<NameValuePair> upload_array = new ArrayList<NameValuePair>();
upload_array.add(new BasicNameValuePair("mFirstname[0]", "FirstName 1"));
upload_array.add(new BasicNameValuePair("mFirstname[1]", "FirstName 2"));
upload_array.add(new BasicNameValuePair("mLastname[0]", "LastName 1"));
upload_array.add(new BasicNameValuePair("mLastname[1]", "LastName 2"));
upload_array.add(new BasicNameValuePair("mNickname[0]", "NickName 1"));
upload_array.add(new BasicNameValuePair("mNickname[1]", "NickName 2"));
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost("http://url/script.php");
HttpResponse response = null;
try {
httppost.setEntity(new UrlEncodedFormEntity(upload_array));
response = httpclient.execute(httppost);
} catch (Exception e) {
e.printStackTrace();
}
在PHP中:
<?php
$connect = mysqli_connect("***","***","***", "***");
if(mysqli_connect_errno($connect))
{
echo "Failed to connect to MySQL: " . mysqli_connect_error();
}
else
{
echo "success";
}
$query = mysqli_prepare("INSERT INTO `namelist` (`firstname`,`lastname`,`nickname`)
VALUES(?,?,?)");
$mFirstname = $_POST['mFirstname'];
$mLastname = $_POST['mLastname'];
$mNickname = $_POST['mNickname'];
foreach($mFirstname as $key as $key => $value) {
$query->bind_param('sss',$value["mFirstname"],$value["mLastname"],$value["mNickname"];
$query->execute();
}
mysqli_close($connect);
?>
错误是否已经在代码的Android部分发生了,或者这个PHP脚本是否只是没有读取我正确发送的数据?任何见解都会非常受欢迎。
答案 0 :(得分:1)
好的,我使用JSON数组完成了这项工作。如果有人使用它,这是它的方式:
Android,创建JSON字符串:
//Create JSON string start
String json_string ="{\"upload_fishes\":[";
//Repeat and loop this until all objects are added (and add try+catch)
JSONObject obj_new = new JSONObject();
obj_new.put("fish_id", your_looped_string_1[i]);
obj_new.put("fish_lat", your_looped_string_2[i]);
obj_new.put("fish_lon", your_looped_string_3[i]);
json_string = json_string + obj_new.toString() + ",";
//Close JSON string
json_string = json_string.substring(0, json_string.length()-1);
json_string += "]}";
Android将数据发送到PHP(添加try + catch):
HttpParams httpParams = new BasicHttpParams();
HttpConnectionParams.setConnectionTimeout(httpParams, TIMEOUT_MILLISEC);
HttpConnectionParams.setSoTimeout(httpParams, TIMEOUT_MILLISEC);
HttpClient client = new DefaultHttpClient(httpParams);
String url = "http://yourserver.com/script.php";
HttpPost request = new HttpPost(url);
request.setEntity(new ByteArrayEntity(json_string.getBytes("UTF8")));
request.setHeader("json", json_string);
HttpResponse response = client.execute(request);
Log.d("FISHY", response.getStatusLine().toString());
PHP脚本:
<?php
//CONNECT TO THE DATABASE
$DB_HOST = 'yourhost.com';
$DB_USER = 'user';
$DB_PASS = 'password';
$DB_NAME = "db_name";
$mysqli = new mysqli($DB_HOST, $DB_USER, $DB_PASS, $DB_NAME);
if(mysqli_connect_errno())
{
// echo "Failed to connect to MySQL: " . mysqli_connect_error();
}
else
{
// echo "Connected to MySQL";
}
$postdata = file_get_contents("php://input");
$data = json_decode($postdata, true);
if (is_array($data['upload_fishes'])) {
foreach ($data['upload_fishes'] as $record) {
$fid = $record['fish_id'];
$flat = $record['fish_lat'];
$flon = $record['fish_lon'];
mysqli_query($mysqli,"INSERT INTO `fishes`(`fish_type_id`, `fish_lat`, `fish_lon`) VALUES ($fid, $flat, $flon)");
}
}
mysqli_close($mysqli);
?>