Scrap images from google images with customs pre filled dorking options
- See changelog
- Tell it in my github issues dont be afraid :)
npm i google-img-scrap
const {
GOOGLE_IMG_SCRAP,
GOOGLE_IMG_INVERSE_ENGINE_URL,
GOOGLE_IMG_INVERSE_ENGINE_UPLOAD,
GOOGLE_QUERY,
} = require("google-img-scrap");
// OR
import {
GOOGLE_IMG_SCRAP,
GOOGLE_IMG_INVERSE_ENGINE_URL,
GOOGLE_IMG_INVERSE_ENGINE_UPLOAD,
GOOGLE_QUERY,
} from "google-img-scrap";
- "search"
string
what you want to search - "proxy"
AxiosProxyConfig
configure a proxy with axios proxy - "excludeWords"
string[]
exclude some words from the search - "domains"
string[]
filter by domains - "excludeDomains"
string[]
exclude some domains - "safeSearch"
boolean
active safe search or not for nsfw for example - "custom"
string
add extra query - "urlMatch"
string[][]
get image when an url match a string (example: "cdn") |example below
- "filterByTitles"
string[][]
filter images by titles |example below
- "query"
GoogleQuery
set a query (can be [TYPE, DATE, COLOR, SIZE, LICENCE, EXTENSION]) (use GOOGLE_QUERY items |example below
- "limit"
number
to limit the size of the results
{
url: 'https://images.google.com/search?tbm=isch&tbs=&q=cats',
search: "cats",
result: [
{
id: 'K6Qd9XWnQFQCoM',
title: 'Domestic cat',
url: 'https://i.natgeofe.com/n/548467d8-c5f1-4551-9f58-6817a8d2c45e/NationalGeographic_2572187_2x1.jpg',
originalUrl: 'https://www.nationalgeographic.com/animals/mammals/facts/domestic-cat',
height: 1536,
width: 3072
},
{
id: 'HkevFQZ5DYu7oM',
title: 'Cat - Wikipedia',
url: 'https://upload.wikimedia.org/wikipedia/commons/1/15/Cat_August_2010-4.jpg',
originalUrl: 'https://en.wikipedia.org/wiki/Cat',
height: 2226,
width: 3640
},
...
]
}
Search cats images
const test = await GOOGLE_IMG_SCRAP({
search: "cats",
});
console.log(test);
The second parameter is like GOOGLE_IMG_SCRAP it include all type of options omitting search. (Omit<Config, "search">)
const test = await GOOGLE_IMG_INVERSE_ENGINE_URL(
"https://upload.wikimedia.org/wikipedia/commons/1/15/Cat_August_2010-4.jpg",
{ limit: 5 }
);
console.log(test);
const imageBuffer = fs.readFileSync("demonSlayer.png");
const test = await GOOGLE_IMG_INVERSE_ENGINE_UPLOAD(imageBuffer, {
limit: 5,
});
console.log(test);
All query options are optional (see below for all the options) and need to be in uppercase. You can combine as much as you want. Find all possible query options below.
const test = await GOOGLE_IMG_SCRAP({
search: "cats",
query: {
TYPE: GOOGLE_QUERY.TYPE.CLIPART,
LICENCE: GOOGLE_QUERY.LICENCE.COMMERCIAL_AND_OTHER,
EXTENSION: GOOGLE_QUERY.EXTENSION.JPG,
},
});
console.log(test);
const test = await GOOGLE_IMG_SCRAP({
search: "cats",
limit: 5,
});
console.log(test);
See axios documentation to setup the proxy
const test = await GOOGLE_IMG_SCRAP({
search: "cats",
proxy: {
protocol: "https",
host: "example.com",
port: 8080,
},
});
console.log(test);
Only scrap from a specific domain
const test = await GOOGLE_IMG_SCRAP({
search: "cats",
domains: ["alamy.com", "istockphoto.com", "vecteezy.com"],
});
console.log(test);
const test = await GOOGLE_IMG_SCRAP({
search: "cats",
excludeDomains: ["istockphoto.com", "alamy.com"],
});
console.log(test);
If you don' like black cats and white cats
const test = await GOOGLE_IMG_SCRAP({
search: "cats",
excludeWords: ["black", "white"], //If you don't like black cats and white cats
});
console.log(test);
const test = await GOOGLE_IMG_SCRAP({
search: "cats",
safeSearch: false,
});
console.log(test);
const test = await GOOGLE_IMG_SCRAP({
search: "cats",
custom: "name=content&name2=content2",
});
console.log(test);
const test = await GOOGLE_IMG_SCRAP({
search: "cats",
//will build something like this "(draw and white) or (albino and white)"
filterByTitles: [
["draw", "white"],
["albino", "white"],
],
//will build something like this "(cdn and wikipedia) or (cdn istockphoto)"
urlMatch: [
["cdn", "wikipedia"],
["cdn", "istockphoto"],
],
});
console.log(test);
{
SIZE: {
LARGE,
MEDIUM,
ICON
},
COLOR: {
BLACK_AND_WHITE,
TRANSPARENT,
RED,
BLUE,
PURPLE,
ORANGE,
YELLOW,
GREEN,
TEAL,
PINK,
WHITE,
GRAY,
BLACK,
BROWN
},
TYPE: {
CLIPART,
DRAW,
GIF
},
EXTENSION: {
JPG,
GIF,
BMP,
PNG,
SVG,
WEBP,
ICO,
RAW
},
DATE: {
DAY,
WEEK,
MONTH,
YEAR
},
LICENCE: {
CREATIVE_COMMONS,
COMMERCIAL_AND_OTHER
}
}