need thumbnails? scraper is a lightweight node.js package designed to return high quality and highly relevant images from a source url fast.
installation
npm install scraper-js
import scraper from "scraper-js";
const url =
"https://barackobama.medium.com/my-2022-end-of-year-lists-ba76b6278801";
const result = await scraper.scrape(url);
Calling scrape
returns a ScrapeResult
object:
export interface ScrapeResult {
html: string;
images: RankedImage[];
linkedData: Thing | null;
openGraph:
| scrapeOpenGraphData.successResultObject
| scrapeOpenGraphData.errorResultObject;
featureImage?: RankedImage | null;
}
The recommended version of node.js is 18
.
//
// scraperapp
//
// thumbnail scraping http server. usage is as follows:
// get the address to scrape from the parameters passed to the url
// e.g. localhost:1337/scrape?url=http://www.reddit.com; address to scrape => http://www.reddit.com
// response will be an array of image urls => [http://image1.jpg, http://image2.jpg, ...]
//
// authored by Jason Ibrahim
// copyright (c) 2015 Jason Ibrahim
//
// initialize dependencies
const http = require("http"),
https = require("https"),
url = require("url"),
scraper = require("scraper-js");
// set the port
const port = process.env.port || 80;
// create the server
const server = http
.createServer(function (req, res) {
const scrapereg = new RegExp(/^(\/scrape)/),
query = url.parse(req.url, true).query,
address = query.url,
scraper = new Scraper.Scraper();
// only listen for api calls to /scrape
if (!req.url.match(scrapereg)) {
res.writeHead(404);
res.end("Did you mean /scrape?");
}
res.writeHead(200, { "Access-Control-Allow-Origin": "*" });
// scraper returns a promise that will resolve an array of `RankedImage`
scraper.scrape(address).then(
function (result) {
res.end(JSON.stringify(result.images));
},
function (error) {
res.writeHead(404);
res.end(JSON.stringify([error]));
}
);
// if we don't get at least one thumbnail within 8 seconds, quit
setTimeout(function () {
res.writeHead(408);
res.end(JSON.stringify(["timeout."]));
}, 8000);
})
.listen(port);
console.log("Scraping on", port);
improvements, features, bug fixes and any other type of contribution are welcome to this project. please feel free to extend what has been started here and if it solves a particular problem, please submit a pull request so we can share it with others.