UPDATE
Я нашел эту интересную ссылку, как решить вашу проблему в PHP . Я думаю, что вы забыли заменить space
на +
, как показано в ссылке.
Я взял этот круг из http://images -mediawiki-sites.thefullwiki.org / 04/1/7/5 / 6204600836255205.png в качестве образца, который выглядит следующим образом:
Затем я прошёл через http://www.greywyvern.com/code/php/binary2base64, что вернуло меня:

сохранил эту строку в base64
, которую я прочитал в своем коде.
var fs = require('fs'),
data = fs.readFileSync('base64', 'utf8'),
base64Data,
binaryData;
base64Data = data.replace(/^data:image\/png;base64,/, "");
base64Data += base64Data.replace('+', ' ');
binaryData = new Buffer(base64Data, 'base64').toString('binary');
fs.writeFile("out.png", binaryData, "binary", function (err) {
console.log(err); // writes out file without error, but it's not a valid image
});
Я получаю круг обратно, но забавно то, что размер файла изменился:) ...
END
Когда вы читаете обратно изображение, я думаю, вам нужно настроить заголовки
Например, imagepng со страницы PHP:
<?php
$im = imagecreatefrompng("test.png");
header('Content-Type: image/png');
imagepng($im);
imagedestroy($im);
?>
Я думаю, что вторая строка header('Content-Type: image/png');
важна, иначе ваше изображение не будет отображаться в браузере, а просто набор двоичных данных отображается в браузере.
В Экспресс вы просто используете что-то вроде ниже. Я собираюсь показать ваш граватар, который расположен в http://www.gravatar.com/avatar/cabf735ce7b8b4471ef46ea54f71832d?s=32&d=identicon&r=PG
и это файл JPEG, когда вы curl --head http://www.gravatar.com/avatar/cabf735ce7b8b4471ef46ea54f71832d?s=32&d=identicon&r=PG
. Я запрашиваю только заголовки, потому что в противном случае curl отобразит кучу бинарных файлов (Google Chrome сразу же перейдет к загрузке) на консоль:
curl --head "http://www.gravatar.com/avatar/cabf735ce7b8b4471ef46ea54f71832d?s=32&d=identicon&r=PG"
HTTP/1.1 200 OK
Server: nginx
Date: Wed, 03 Aug 2011 12:11:25 GMT
Content-Type: image/jpeg
Connection: keep-alive
Last-Modified: Mon, 04 Oct 2010 11:54:22 GMT
Content-Disposition: inline; filename="cabf735ce7b8b4471ef46ea54f71832d.jpeg"
Access-Control-Allow-Origin: *
Content-Length: 1258
X-Varnish: 2356636561 2352219240
Via: 1.1 varnish
Expires: Wed, 03 Aug 2011 12:16:25 GMT
Cache-Control: max-age=300
Source-Age: 1482
$ mkdir -p ~/tmp/6922728
$ cd ~/tmp/6922728/
$ touch app.js
app.js
var app = require('express').createServer();
app.get('/', function (req, res) {
res.contentType('image/jpeg');
res.sendfile('cabf735ce7b8b4471ef46ea54f71832d?s=32&d=identicon&r=PG');
});
app.get('/binary', function (req, res) {
res.sendfile('cabf735ce7b8b4471ef46ea54f71832d?s=32&d=identicon&r=PG');
});
app.listen(3000);
$ wget "http://www.gravatar.com/avatar/cabf735ce7b8b4471ef46ea54f71832d?s=32&d=identicon&r=PG"
$ node app.js