javascript - nodejs中使用request库怎么抓取网页中的图片
问题描述
const koa = require(’koa’);const request = require(’request’);const fs = require(’fs’);const path = require(’path’);function requestAsync(url) { return new Promise((resolve, reject) => {request({ url: url}, (err, res, body) => { if (err) {reject(err); } else {resolve(body); }}) });}function writeFileAsync(path, data, option) { return new Promise((resolve, reject) => {fs.writeFile(path, data, option, (err)=> { if (err) {reject(err); } else {resolve(); }}) });}const app = new koa();app.use(async (ctx) => { let url = ’http://pubimage.360doc.com/index7/bannerl_1.jpg’; let filepath = path.join(__dirname, ’./images/详情’); filepath = filepath + ’/1.jpg’; // request(url).pipe(fs.createWriteStream(filepath));这个可以正常抓取图片 let data = await requestAsync(url); let buffer = Buffer.from(data); await writeFileAsync(filepath, buffer); ctx.type = ’jpg’; ctx.body = buffer;})app.listen(3000);console.log(`starting at ${3000}`);
我把request 和 writefile 都写成了promise的形式,抓取html是可以的,抓取图片就不行了
一开始data 输出是string类型,也就是request 的body是string类型,我就使用Buffer.from
转为buffer类型,也是不行,改为Buffer.from(data, ’base64’)也是不行,但就是使用 request(url).pipe(fs.createWriteStream(filepath))就可以请问一下哪里出错了
问题解答
回答1:/q/10...
相关文章:
1. javascript - vue 怎么渲染自定义组件2. javascript - [MUI 子webview定位]3. mysql - 记得以前在哪里看过一个估算时间的网站4. 请教各位大佬,浏览器点 提交实例为什么没有反应5. javascript - 怎么看网站用了什么技术框架?6. javascript - Vue 的依赖追踪属于单向数据绑定还是双向绑定?7. javascript - node服务端渲染的困惑8. python3.x - c++调用python39. 学习这个是不是要先学下css?10. javascript - 单个页面执行多个jsonp的ajax请求,如何判断一个ajax请求执行完毕执行再另一个?
