Skip to main content gottem  — one API for every scraper.
Social
Verified

Tumblr Scraper

Extract blog posts, reblogs, tags, and multimedia content from Tumblr microblogging platform. Built on spider-browser .

Get started Docs
target
tumblr.com
success rate
99.9%
latency
~4ms
Quick start

Extract data in minutes.

tumblr-scraper.ts
import { SpiderBrowser } from "spider-browser";

const spider = new SpiderBrowser({
  apiKey: process.env.SPIDER_API_KEY!,
  stealth: 2,
});

await spider.connect();
const page = spider.page!;
await page.goto("https://www.tumblr.com/tagged/photography");
await page.content(10000);

const data = await page.evaluate(`(() => {
  const posts = [];
  document.querySelectorAll("[data-cell-id]").forEach(el => {
    const author = el.querySelector(".post-info-tumblelog a")?.textContent?.trim();
    const text = el.querySelector(".post-body")?.textContent?.trim();
    const notes = el.querySelector(".note-count")?.textContent?.trim();
    if (author) posts.push({ author, text: text?.slice(0, 300), notes });
  });
  return JSON.stringify({ total: posts.length, posts: posts.slice(0, 10) });
})()`);

console.log(JSON.parse(data));
await spider.close();
ready to run · spider-browser · TypeScript
Fetch API

One endpoint for tumblr.com.

Structured JSON from tumblr.com with a single POST. AI-resolved selectors, cached on the first call.

POST /fetch/tumblr.com/
Post contentAuthorNotesTagsReblog countMedia URL
cURL
curl -X POST https://api.spider.cloud/fetch/tumblr.com/ \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{"return_format": "json"}'
Python
import requests

resp = requests.post(
    "https://api.spider.cloud/fetch/tumblr.com/",
    headers={
        "Authorization": "Bearer YOUR_API_KEY",
        "Content-Type": "application/json",
    },
    json={"return_format": "json"},
)
print(resp.json())
Node.js
const resp = await fetch("https://api.spider.cloud/fetch/tumblr.com/", {
  method: "POST",
  headers: {
    "Authorization": "Bearer YOUR_API_KEY",
    "Content-Type": "application/json",
  },
  body: JSON.stringify({ return_format: "json" }),
});
const data = await resp.json();
console.log(data);
Extraction

Fields you can pull.

Post contentAuthorNotesTagsReblog countMedia URLPost typeTimestamp
Stealth

Platform bypass

Residential proxies and fingerprint rotation for tumblr.com access.

Rendering

SPA rendering

Full JavaScript execution for React-based feeds and dynamic content.

Data

Profile & post data

Extract public profiles, posts, engagement metrics, and connections.

Related

More Social scrapers.

Start

Start scraping tumblr.com.

Grab an API key and call the endpoint above. The first request resolves the config; every request after hits cache.