Podobnie jak w opisie, robię zdjęcie w systemie Android. Jest skompresowany i dodany do byte[]
, a następnie base64encoded
. Wysyła z usługą JSON do mojego serwisu internetowego, gdzie "powinien" zostać zdekodowany i zapisany w wierszu tabeli SQL wiersz. Mogę zapisać zakodowany ciąg w osobnym wierszu, więc wiem, że się tam dostanie.Wysyłanie obrazu Base64 z systemu Android za pomocą JSON do serwisu WWW php, dekodowanie, zapisywanie do SQL
Czy ktoś może spojrzeć na to i pokazać mi, gdzie robię to źle? * Przepraszam za długi kod. Nie chcę tego przegapić, jeśli ktoś zaoferuje mi pomoc!
ANDROID SIDE
@Override
protected String doInBackground(String... args) {
// TODO Auto-generated method stub
// Check for success tag
int success;
stream = new ByteArrayOutputStream();
picture.compress(Bitmap.CompressFormat.JPEG, 50, stream);
image = stream.toByteArray();
String ba1 = Base64.encodeToString(image, Base64.DEFAULT);
SharedPreferences sp = PreferenceManager.getDefaultSharedPreferences(MainScreen.this);
String post_username = sp.getString("username", "anon");
try {
ArrayList<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("username", post_username));
params.add(new BasicNameValuePair("picture", ba1));
JSONObject json = jsonParser.makeHttpRequest(POST_COMMENT_URL,
"POST", params);
success = json.getInt(TAG_SUCCESS);
if (success == 1) {
Log.d("Picture Added!", json.toString());
//finish();
return json.getString(TAG_MESSAGE);
} else {
Log.d("Upload Failure!", json.getString(TAG_MESSAGE));
return json.getString(TAG_MESSAGE);
}
} catch (JSONException e) {
e.printStackTrace();
}
return null;
}
protected void onPostExecute(String file_url) {
// dismiss the dialog once product deleted
pDialog.dismiss();
if (file_url != null) {
Toast.makeText(MainScreen.this, file_url, Toast.LENGTH_LONG)
.show();
}
}
}
}
PHP SIDE
<?php
require("config.inc.php");
if (!empty($_POST)) {
$user = $_POST['username'];
$data = $_POST['picture'];
$data = base64_decode($data);
$im = imagecreatefromstring($data);
header('Content-Type: image/jpeg', true);
ob_start();
imagejpeg($im);
$imagevariable = ob_get_contents();
ob_end_clean();
$query = "INSERT INTO pictures (username, photo, rawdata) VALUES (:user, :photo, :raw) ";
$query_params = array(
':user' => $user,
':photo' => $imagevariable,
':raw' => $_POST['picture']
);
try {
$stmt = $db->prepare($query);
$result = $stmt->execute($query_params);
}
catch (PDOException $ex) {
$response["success"] = 0;
$response["message"] = "Database Error. Couldn't add post!";
die(json_encode($response));
}
$response["success"] = 1;
$response["message"] = "Picture Successfully Added!";
echo json_encode($response);
} else {
}
?>
Jakiego rodzaju wartością jest zestaw 'rawdata' ustawiony w MySQL? Blob czy coś innego? – Pitchinnate
Używam rawdata do potwierdzenia, że robi to od aplikacji aż do bazy danych. rawdata to tylko wiersz tekstu i zapisuje dane base64. Nie potrzebuję tego po tym, jak mogę zdekodować i zapisać obraz. To było tylko do testów. – JeffK
Byłbym również szczęśliwy, używając wielostanowiskowości, gdyby ktoś mógł mnie przez to przejść. Pomyślałem, że zastanawianie się, jak rozszyfrować tę bazę64 byłoby łatwiejsze. – JeffK