我正在使用以下代码从我的Android应用程序中拍照:
if (requestCode == CAMERA_REQUEST && resultCode == RESULT_OK){
photo = (Bitmap) data.getExtras().get("data");
ByteArrayOutputStream baos = new ByteArrayOutputStream();
photo.compress(Bitmap.CompressFormat.JPEG, 40, baos);
byte[] photoByte = baos.toByteArray();
encodedImage = Base64.encodeToString(photoByte,Base64.DEFAULT);
}
我正在encodedImage
通过POST将此字符串发送到我的PHP服务器,并将其接收到$encodedImage
。我有一个数据库,其中有一个myImage
type字段MEDIUMBLOB
。我试图保存在encodedimage
中,myImage
但是它被保存为损坏的图像。我尝试将另存为,base64_decode($encodedImage)
但是无论如何也没有用。
我想做三件事:
将图像保存到服务器端数据库(BLOB)
显示图像到网页
将其发送回Android应用。
我在理解上述任务所需的不同格式的图像转换时遇到问题。
对于我当前的项目,我不想将图像保存到文件夹并提供数据库链接,因此该选项对我来说是关闭的。
我的PHP代码保存图像:
$baseImage = $_POST['baseImage'];
$blobImage = base64_decode($baseImage);
$query = "INSERT INTO `complaints`(`myImage`,...) VALUES ('$blobImage',...)"
$result = mysqli_query($conn,$query);
使用关键字_binary前缀SQL。
$query = "INSERT INTO `complaints`
(`myImage`,...)
VALUES (_binary'".addcslashes($blobImage, "\x00\'\"\r\n")."',...)"
另外,使用CURL设置测试环境,以便您可以反复向其抛出base64编码的图像。这将是您需要大量调试的情况。
<?php
$f = fopen('sample.jpg.base64.txt', 'w');
$i = fopen('sample.jpg', 'r');
if (!$i) { die("cannot open sample.jpg\n"); }
$bytes = '';
while ( ! feof($i)) {
$bytes .= fread($i, 4096);
}
fclose($i);
fputs($f, base64_encode( $bytes ) );
fclose($f);
然后使用curl重复发布它并调试PHP
curl -X PUT "http://localhost/myimport.php" -F "baseImage=@./sample.jpg.base64.txt"
调整您的PHP脚本,只需将数据写到硬盘驱动器上的文件中并在其中检查即可。写出编码和解码的多个版本。
就个人而言,我不会对从Android到PHP的字节进行base64编码,但我会将base64编码在mysql中。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句