简体   繁体   English

nodejs / restify - 图像代理服务器

[英]nodejs / restify - Image proxy server

I'm trying to write a simple image proxy server (please feel free to correct me if this isn't the right wording). 我正在尝试编写一个简单的图像代理服务器(如果这不是正确的措辞,请随时纠正我)。

Use case: 使用案例:

This is my current version. 这是我目前的版本。 It appears to serve a broken image file (and open a download prompt when opened via a web browser...). 它似乎提供了一个损坏的图像文件(并通过Web浏览器打开时打开下载提示...)。

UPDATED: Working version below. 更新:下面的工作版本。

    var restify = require("restify");
    var http = require("http");
    var request = require("request");

    var server = restify.createServer();

    server.listen(1234, function() {
        console.log("%s listening at %s", server.name, server.url);
    });

    server.get("/image",  getImage);

    function getImage(req, res, next) {

       var imageURL = "http://png-5.findicons.com/files/icons/409/witchery/128/cat.png";

       http.get(imageURL, function(response) {

          var imageSize = parseInt(response.header("Content-Length"));
          var imageBuffer = new Buffer(imageSize);
          var bytes = 0;

          response.setEncoding("binary");

          response.on("data", function(chunk) {
            imageBuffer.write(chunk, bytes, "binary");
            bytes += chunk.length;
          });

          response.on("end", function() {
            console.log("Download complete, sending image.");
            res.setHeader("Content-Type", "image/png");
            res.send(imageBuffer);
            return next();
          });
   }

Why not simply pipe straight through? 为什么不直接管道?

app.get('/:path', function(req, res) {

    request.get('www.imgserver.com/images/' + path).pipe(res);
}

Ok I eventually got it :) 好吧我终于明白了:)

http.get(imageURL, function(response) {

        var imageSize = parseInt(response.header("Content-Length"));
        var imageBuffer = new Buffer(imageSize);
        var bytes = 0;

        response.setEncoding("binary");

        response.on("data", function(chunk) {
            imageBuffer.write(chunk, bytes, "binary");
            bytes += chunk.length;
        });

        response.on("end", function() {
            console.log("Download complete, sending image.");
            res.setHeader("Content-Type", "image/png");
            res.send(imageBuffer);
            return next();
        });

  }

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM