图片列表大概有1万个图片地址,
使用nodejs下载的时候,莫名其妙就会出现错误。
基本代码如下:
var downloadImage2 = function (src) {
var iArr = src.split("/");
var imageName = iArr[iArr.length - 1];
//console.log("Download begin: " + imageSrc);
var download = function(uri, filename, callback) {
request.head(uri, function(err, res, body) {
// console.log('content-type:', res.headers['content-type']);
// console.log('content-length:', res.headers['content-length']);
if (uri) {request(uri).pipe(fs.createWriteStream(filename)).on('close', callback);}
});
};
download(src, "./images/" + imageName, function() {
console.log('done: ' + index++);
});
}
出现的错误也有点莫名其妙,有时候是:
events.js:160
throw er; // Unhandled 'error' event
^
Error: Invalid URI "undefined"
at Request.init (/Users//dirread/node_modules/request/request.js:275:31)
at new Request (/Users/dirread/node_modules/request/request.js:129:8)
at request (/Users/dirread/node_modules/request/index.js:55:10)
at Request._callback (/Users//down.js:21:11)
at self.callback (/Users//dirread/node_modules/request/request.js:187:22)
at emitOne (events.js:96:13)
at Request.emit (events.js:188:7)
Invalid URI "undefined"
給src容個錯,傳錯的位址就不要下載了。
改成用fs.writeFile的方式試試看。
其實給URI加一個判空處理很簡單,但是以我的經驗來看,問題是出現了在了解析URL的時候出現了錯誤,導致有些資源URL沒有拿到正確的地址。建議從這個角度出發來排查。