我已将.png
图像文件读入数组缓冲区。
var readSingleFile = function(e) {
var file = e.target.files[0];
if (!file) {
return;
}
var reader = new FileReader();
reader.onload = function(e) {
var contents =new Int8Array(e.target.result);
$.ajax({
url: 'saveBinaryData.php',
type: 'POST',
contentType: 'application/octet-stream',
data: contents,
processData: false
});
};
reader.readAsArrayBuffer(file);
}
这是发布到AJAX描述的PHP文件。
如何将此二进制数据转换为图像格式?
到目前为止我的代码:
<?php
if($data=file_get_contents($_POST)){
echo "Error! Data not read!";
return;
}
$data = imagecreatefromstring($data);
var_dump($data);
file_put_contents("recentImage1.png", $data);
?>
这些取自Google中的各种解决方案。图像文件已创建但不包含任何内容,因此无法打开。
答案 0 :(得分:1)
这是保存上传文件的简单工作演示:
JS:
<script src='https://code.jquery.com/jquery-2.2.3.min.js'></script>
<script>upload = function() {
f = new FileReader();
f.onload = function(e) {
$.ajax({
url: '?upload',
type: 'POST',
contentType: 'application/octet-stream;charset=UTF-8',
data: e.target.result.split(",", 2)[1], //remove text header
processData: false
});
};
f.readAsDataURL($('input')[0].files[0]);
}
</script>
HTML:
<input type="file" />
<button onclick="upload()">Upload</button>
和PHP:
<?php
if (isset($_GET['upload'])) {
$file = file_get_contents('php://input');
file_put_contents('recentImage1.png', base64_decode($file));
}
所有代码都在单个文件中,只需分成3个部分以便更好地进行格式化。
二手帖子: