ホームページ >ウェブフロントエンド >jsチュートリアル >Node.js で画像をダウンロードするにはいくつかの方法があります
今回は、node.jsで画像をダウンロードする方法をいくつか紹介します。node.jsで画像をダウンロードする際の注意事項は何ですか?実際のケースを見てみましょう。
具体的なコードは次のとおりです:
var request=require("request"); var fs=require("fs"); function download1(url,filename,fn){ request(url).pipe(fs.createWriteStream(filename).on("close",function(err,res){ if(err){ console.log(err); }else{ fn&&fn(); } })) } function download2(url,filename,fn){ request.get({uri:url, encoding:'binary'},function(err,res){ if(!err){ fs.writeFile(filename,res.body,"binary",function(err,res){ if(!err){ fn&&fn(); }else{ console.log(err); } }) } }) }
追記: リモートイメージをダウンロードするnodejsの実装コードを見てみましょう: 具体的なコードは次のとおりです:
var express = require('express'); var request = require('request'); var http = require('http'); var url = require('url'); var fs = require("fs"); var router = express.Router(); /* GET home page. */ router.get('/', function (req, res, next) { var url = "http://www.valu.cn/images/1.gif"; //request('http://www.valu.cn/images/1.gif').pipe(fs.createWriteStream('./public/upload/downImg/logonew.png')); var req = http.get(url, function (res) { var imgData = ""; res.setEncoding("binary"); //一定要设置response的编码为binary否则会下载下来的图片打不开 res.on("data", function (chunk) { imgData += chunk; }); res.on("end", function () { fs.writeFile("./public/upload/downImg/logonew.png", imgData, "binary", function (err) { if (err) { console.log("保存失败"); } console.log("保存成功"); }); }); res.on("error", function (err) { console.log("请求失败"); }); }); req.on('error', function (err) { console.log("请求失败2" + err.message); }); res.render('index', {title: '首页2'}); }); module.exports = router;
この記事の事例を読んだ後は、この方法を習得したと思います。情報については、php 中国語 Web サイトの記事のその他の関連トピックにご注意ください。
推奨読書:
Reactコンポーネントのパフォーマンス最適化の側面とは何ですか
以上がNode.js で画像をダウンロードするにはいくつかの方法がありますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。