如何使用java将长blob(图像)上传到mysql数据库并在php中检索?

时间:2016-04-21 10:25:32

标签: php android mysql blob

我正在开发一个项目,我需要将图像上传到数据库并从数据库中检索图像。

我需要使用java从Android设备上传图像。 这是我实施的内容

json_encode

我将字节数组插入数据库。 这是我的PHP代码检索相同的:

Bitmap bitmap = MediaStore.Images.Media.getBitmap(getContentResolver(), uri);
            // Log.d(TAG, String.valueOf(bitmap));
            ByteArrayOutputStream stream = new ByteArrayOutputStream();
            bitmap.compress(Bitmap.CompressFormat.PNG, 90, stream); //compress to which format you want.
            byte[] byte_arr = stream.toByteArray();
            image_str = Base64.encodeToString(byte_arr, Base64.DEFAULT);

我在这里遇到的问题是文件上传到数据库但是当我从数据库中检索图像时,变量 /** *Get profile_pic*/ public function callmethod($userId){ $stmt = $this->conn->prepare("SELECT profile_pic FROM users WHERE unique_id=?"); $stmt->bind_param('s',$userId); //$result = mysql_query($query) or die(mysql_error()); //$photo = mysql_fetch_array($result); $stmt->execute(); $stmt->store_result(); $stmt->bind_result($profile_pic); $stmt->fetch(); //$obj->picture = base64_encode($profile_pic); //echo $obj; header("Content-Type: image/jpeg"); echo '<img src="data:image/jpeg;base64,<?php echo base64_encode($profile_pic); ?>" />'; } 为空,因此图像没有显示。

我需要它能够在android中使用java检索图像。我可以通过使用$profile_pic格式对值检索进行编码吗?

请让我知道我做错了什么。 TIA

1 个答案:

答案 0 :(得分:1)

 /**
*Get profile_pic*/
public function callmethod($userId){
$stmt = $this->conn->prepare("SELECT profile_pic FROM users WHERE unique_id=?");
$stmt->bind_param('s',$userId); 
//$result = mysql_query($query) or die(mysql_error()); 
//$photo = mysql_fetch_array($result); 
$stmt->execute();
$stmt->store_result();
$stmt->bind_result($profile_pic);
while ($stmt->fetch()) {
    echo "<img src='data:image/jpeg;base64,".$profile_pic."' />";
}
 //$obj->picture = base64_encode($profile_pic);
//echo $obj;


}

好的尝试这个代码吧。你不需要     header("Content-Type: image/jpeg"); 功能。这是你的PHP代码中的错误。此代码将使用basc64创建img标记。

现在为android部分。

在php中更改此内容。

while ($stmt->fetch()) {
    echo "<img src='data:image/jpeg;base64,".$profile_pic."' />";
}

while ($stmt->fetch()) {
    echo $profile_pic;
}

这将是你的Android部分。

byte[] decodedString = Base64.decode(strBase64, Base64.DEFAULT);
Bitmap decodedByte = BitmapFactory.decodeByteArray(decodedString, 0, decodedString.length); 
image.setImageBitmap(decodedByte);