Tutorial · TikTok Ad Library

💎 Ruby Step-by-step

How to scrape TikTok Ad Library ads
with Ruby.

Extract ad data from TikTok Ad Library. Real code, real responses, real production patterns — paste it into your project and ship.

Overview

Learn how to scrape TikTok Ad Library ads using Ruby. This comprehensive guide will walk you through the entire process, from setup to implementation.

What You'll Learn

  • • Setting up your development environment
  • • Installing the required HTTP client
  • • Authenticating with the ScrapeCreators API
  • • Making requests to TikTok Ad Library
  • • Handling responses and errors
  • • Best practices for production use

What You'll Get

  • • Access to ads data
  • • JSON formatted responses
  • • Real-time data access
  • • Scalable solution
  • • Error handling patterns
  • • Performance optimization tips

Prerequisites

1. API Key

First, you'll need a ScrapeCreators API key to authenticate your requests.

Sign up at app.scrapecreators.com to get your free API key with 100 requests.

2. Development Environment

Make sure you have the following installed:

  • Ruby and its dependencies
  • • A code editor (VS Code, Sublime, etc.)
  • • Basic understanding of API requests
  • • Command line interface access

Step 1: Install HTTP Client

HTTParty is a Ruby library that makes HTTP requests easy

gem
gem install httparty

Step 2: API Implementation

Now let's make a request to the TikTok Ad Library API using Ruby. Replace YOUR_API_KEY with your actual API key.

Ruby
require 'httparty'
require 'json'

API_KEY = 'YOUR_API_KEY'

def scrape
  response = HTTParty.get(
    "https://api.scrapecreators.com/v1/tiktok/ad-library/ad",
    headers: {
      'x-api-key' => API_KEY,
      'Content-Type' => 'application/json'
    },
    query: {
        'ad_id' => '7642386438915309575'
    }
  )

  puts 'Response:'
  puts JSON.pretty_generate(response.parsed_response)
  response.parsed_response
rescue => e
  puts "Error: #{e.message}"
  nil
end

# Usage
result = scrape

Step 3: Testing Your Code

API Parameters

This endpoint accepts the following parameters:

ad_idRequired(string)

TikTok Top Ads material/ad ID, or a Top Ads detail URL.

Example: 7642386438915309575

Run Your Code

Execute your script to test the API connection. You should see a JSON response with TikTok Ad Library ads data.

✅ Success: You should receive a structured JSON response containing the requested data.

Expected Response

Here's an example of the JSON response you'll receive:

Sample Response
{
  "success": true,
  "credits_remaining": 49996315006,
  "ad_title": "I thought this was a gimmick until I tried it! A wrinkled shirt, one button, and a few minutes later... ready to wear. Tap the link in bio and see why everyone’s talking about Bellairon before it sells out. @Bellairon LLC ",
  "brand_name": "",
  "comment": 1,
  "cost": 1,
  "country_code": [
    "TR",
    "US"
  ],
  "ctr": 0.5,
  "favorite": false,
  "has_summary": false,
  "highlight_text": "",
  "id": "7646829987799334920",
  "industry_key": "label_22108000000",
  "is_search": false,
  "keyword_list": null,
  "landing_page": "https://www.amazon.com/dp/B0DRTC8XBW?ref=cm_sw_r_cso_wa_apin_dp_71W8F02XC4M4QZRQ5RQN&ref_=cm_sw_r_cso_wa_apin_dp_71W8F02XC4M4QZRQ5RQN&social_share=cm_sw_r_cso_wa_apin_dp_71W8F02XC4M4QZRQ5RQN&oas=true&utm_source=tiktok&utm_medium=paid&utm_id=__CAMPAIGN_ID__&utm_campaign=__CAMPAIGN_NAME__",
  "like": 92,
  "objective_key": "campaign_objective_reach",
  "objectives": [
    {
      "label": "campaign_objective_reach",
      "value": 5
    }
  ],
  "pattern_label": [],
  "share": 1,
  "source": "Others",
  "source_key": 73,
  "video_info": {
    "vid": "v12044gd0000d8erq07og65h1cq991gg",
    "duration": 89.767,
    "cover": "https://p16-common-sign.tiktokcdn.com/tos-maliva-p-0068c799-us/oIbqBdvfEAiFpgvAOgrQHCF5R0mkDDLiEfvQDS~tplv-noop.image?dr=18692&refresh_token=2cdb79e2&x-expires=1781231880&x-signature=W%2BBTq1VGRRaNnIuMGUpWWSgmOoo%3D&t=9276707c&ps=14f1eb3e&shp=9e36835a&shcp=317596d8&idc=my&VideoID=v12044gd0000d8erq07og65h1cq991gg",
    "video_url": {
      "540p": "https://v16m-default.tiktokcdn.com/3e7ec770348dbc627fc02ea1e8417c25/6a2b7108/video/tos/maliva/tos-maliva-ve-0068c799-us/oIN2GPIRgHAUBHOeNfLk2HBSERoJeIALGC3jAE/?a=0&bti=NTU4QDM1NGA%3D&&bt=315&ft=cApXJCz7ThWHKnz9LGZmo0P&mime_type=video_mp4&rc=Omk6ZWQ7Nzc7OGY8PGVnOkBpajQ8Zms5cjN1OzMzZzczNEBgNDAzXl9hXjMxLzEvXjFiYSNkNm4uMmQ0bmJhLS1kMS9zcw%3D%3D&vvpl=1&l=20260612043631BE40574FD5FFAA863321&btag=e00090000",
      "720p": "https://v16m-default.tiktokcdn.com/9f16ea869602069b9fdad27dc113cb48/6a2b7108/video/tos/maliva/tos-maliva-ve-0068c799-us/ooEipQa9HbhJ4ChzASIngUPhBAdXiABIvxU2E/?a=0&bti=NTU4QDM1NGA%3D&&bt=877&ft=cApXJCz7ThWHKnz9LGZmo0P&mime_type=video_mp4&rc=ZTg3OTQ0NTQzZGVpNWg6NkBpajQ8Zms5cjN1OzMzZzczNEBhNC0yMDViNi8xLV9hX2AuYSNkNm4uMmQ0bmJhLS1kMS9zcw%3D%3D&vvpl=1&l=20260612043631BE40574FD5FFAA863321&btag=e00090000"
    },
    "width": 720,
    "height": 1280
  },
  "voice_over": false,
  "creative_center_url": "https://ads.tiktok.com/business/creativecenter/topads/7646829987799334920/pc/en",
  "detail_analysis": null,
  "interactive_time_analysis": {
    "ctr": {
      "metric": "retain_ctr",
      "analysis": [
        {
          "second": 0,
          "value": 0.048321828136158054
        },
        {
          "second": 1,
          "value": 1
        },
        {
          "second": 2,
          "value": 0.49464413234944066
        },
        {
          "second": 3,
          "value": 0.4746488931206856
        },
        {
          "second": 4,
          "value": 0.5448702689835754
        },
        {
          "second": 5,
          "value": 0.26803142109021666
        },
        {
          "second": 6,
          "value": 0.08521780528445608
        },
        {
          "second": 7,
          "value": 0.20614139490597477
        },
        {
          "second": 8,
          "value": 0
        },
        {
          "second": 9,
          "value": 0.13234944060937873
        },
        {
          "second": 10,
          "value": 0
        },
        {
          "second": 11,
          "value": 0
        },
        {
          "second": 12,
          "value": 0.1685313020709355
        },
        {
          "second": 13,
          "value": 0.17900499880980722
        },
        {
          "second": 14,
          "value": 0
        },
        {
          "second": 15,
          "value": 0.19947631516305642
        },
        {
          "second": 16,
          "value": 0
        },
        {
          "second": 17,
          "value": 0
        },
        {
          "second": 18,
          "value": 0
        },
        {
          "second": 19,
          "value": 0
        },
        {
          "second": 20,
          "value": 0.23613425374910738
        },
        {
          "second": 21,
          "value": 0.4848845512973102
        },
        {
          "second": 22,
          "value": 0
        },
        {
          "second": 23,
          "value": 0
        },
        {
          "second": 24,
          "value": 0
        }
      ],
      "duration": 91,
      "highlight": [
        1,
        4,
        21
      ],
      "percentile": 0.99
    },
    "cvr": {
      "metric": "retain_cvr",
      "analysis": [
        {
          "second": 0,
          "value": 0
        },
        {
          "second": 1,
          "value": 0
        },
        {
          "second": 2,
          "value": 0
        },
        {
          "second": 3,
          "value": 0
        },
        {
          "second": 4,
          "value": 0
        }
      ],
      "duration": 91,
      "highlight": [],
      "percentile": 0.99
    },
    "clicks": {
      "metric": "click_cnt",
      "analysis": [
        {
          "second": 0,
          "value": 0.2631578947368421
        },
        {
          "second": 1,
          "value": 1
        },
        {
          "second": 2,
          "value": 0.15789473684210525
        },
        {
          "second": 3,
          "value": 0.08187134502923976
        },
        {
          "second": 4,
          "value": 0.06432748538011696
        },
        {
          "second": 5,
          "value": 0.023391812865497075
        },
        {
          "second": 6,
          "value": 0.005847953216374269
        },
        {
          "second": 7,
          "value": 0.011695906432748537
        },
        {
          "second": 8,
          "value": 0
        },
        {
          "second": 9,
          "value": 0.005847953216374269
        },
        {
          "second": 10,
          "value": 0
        },
        {
          "second": 11,
          "value": 0
        },
        {
          "second": 12,
          "value": 0.005847953216374269
        },
        {
          "second": 13,
          "value": 0.005847953216374269
        },
        {
          "second": 14,
          "value": 0
        },
        {
          "second": 15,
          "value": 0.005847953216374269
        },
        {
          "second": 16,
          "value": 0
        },
        {
          "second": 17,
          "value": 0
        },
        {
          "second": 18,
          "value": 0
        },
        {
          "second": 19,
          "value": 0
        },
        {
          "second": 20,
          "value": 0.005847953216374269
        },
        {
          "second": 21,
          "value": 0.011695906432748537
        },
        {
          "second": 22,
          "value": 0
        }
      ],
      "duration": 91,
      "highlight": [
        1,
        7,
        21
      ],
      "percentile": 0.99
    },
    "conversion": {
      "metric": "convert_cnt",
      "analysis": [
        {
          "second": 0,
          "value": 0
        },
        {
          "second": 1,
          "value": 0
        },
        {
          "second": 2,
          "value": 0
        },
        {
          "second": 3,
          "value": 0
        },
        {
          "second": 4,
          "value": 0
        },
        {
          "second": 5,
          "value": 0
        },
        {
          "second": 25,
          "value": 0
        }
      ],
      "duration": 91,
      "highlight": [],
      "percentile": 0.99
    },
    "remain": {
      "metric": "play_retain_cnt",
      "analysis": [
        {
          "second": 0,
          "value": 1
        },
        {
          "second": 1,
          "value": 0.18371980698135268
        },
        {
          "second": 2,
          "value": 0.05865040422871536
        },
        {
          "second": 3,
          "value": 0.031688281204154685
        },
        {
          "second": 4,
          "value": 0.021694284824382824
        }
      ],
      "duration": 91,
      "highlight": [],
      "percentile": 0.99
    }
  },
  "recommended_for_you": [
    {
      "ad_title": "Adımlarınıza eğlence katmaya hazır mısınız? \"Hiç böyle çorap görmüş müydünüz?\" diyoruz ve iddiamızı ortaya koyuyoruz! ​Giyimkent Outlet İndirim Çadırı'nda çorap modasına yepyeni bir boyut getirdik. Sevdiğiniz popüler kültür ve kült anime karakterlerini, kolları hareket edebilen bu özel 3 boyutlu tasarım çoraplarla tarzınıza taşıyın.  İster günlük kombinlerinize eğlenceli bir dokunuş yapın, ister arkadaşlarınıza tebessüm ettirecek harika bir hediye seçin. Videomuzdaki gibi ister halay çektirin, ister horon teptirin; seçim sizin! ​Bu benzersiz ve eğlenceli tasarım çoraplarda dev fırsat: 2 Adet Sadece 100 TL! Favori karakterleriniz tükenmeden sizleri de Esenler'deki Giyimkent Outlet indirim çadırımıza bekliyoruz. Adresimiz: Oruçreis mah. Giyimkent Caddesi No:5 Esenler/İstanbul M7 Metro Hattı Giyimkent durağı önü. Hafta içi 10:00 ile 19:00 Hafta Sonu 10:00 - 20:00 Saatleri Arasında açıktır. #alışverişfestivali #kampanya #outlet #giyimkent ",
      "brand_name": "",
      "cost": 0,
      "ctr": 0.63,
      "favorite": false,
      "id": "7644102379697602567",
      "industry_key": "label_22108000000",
      "is_search": false,
      "like": 127,
      "objective_key": "campaign_objective_reach",
      "video_info": {
        "vid": "v1c044g50000d86qrfnog65v7nuvf30g",
        "duration": 13.213,
        "cover": "https://p16-common-sign.tiktokcdn.com/tos-alisg-p-0037/ogCtJD4GUCr8GavLIfI1jAQ9IDvNeGEAfjQgg9~tplv-noop.image?dr=18692&refresh_token=fc9b28a3&x-expires=1781231805&x-signature=zYq%2F3BQnXoM8CMFBFKDON6lhPBs%3D&t=9276707c&ps=14f1eb3e&shp=9e36835a&shcp=317596d8&idc=my&VideoID=v1c044g50000d86qrfnog65v7nuvf30g",
        "video_url": {
          "720p": "https://v16m-default.tiktokcdn.com/1342656e028b133716a1e892a89e214a/6a2b70bd/video/tos/alisg/tos-alisg-pve-0037c001/os3NtUfeIHH1ALjc3Q4IWADrx9BGCBG8IEgejj/?a=0&bti=NTU4QDM1NGA%3D&&bt=837&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=ZDY4NTppZjg4ZWY6Nzc2NEBpajZ5cXk5cml0OzMzODczNEAwYi41YWMwNWMxYGEyM2IyYSMtY3I0MmRrbzNhLS1kMWBzcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000"
        },
        "width": 576,
        "height": 1024
      }
    },
    {
      "ad_title": "O meşhur duruş Trendyol'da! W-010 yelekli takımın fiyatını görenler inanamadı. Bitmeden bak! ",
      "brand_name": "",
      "cost": 0,
      "ctr": 0.55,
      "favorite": false,
      "id": "7637828811991810069",
      "industry_key": "label_22108000000",
      "is_search": false,
      "like": 115,
      "objective_key": "campaign_objective_traffic",
      "video_info": {
        "vid": "v10033g50000d7vgcfnog65lu32nt9gg",
        "duration": 51.1,
        "cover": "https://p16-common-sign.tiktokcdn.com/tos-alisg-p-0051c001-sg/oMIxeMAMnFDvMA1WQ3AgdAhhMGve8f0Ai2AHf9~tplv-noop.image?dr=18692&refresh_token=10c04573&x-expires=1781231843&x-signature=duleOVhUzhXr6QjZB3mFkGF%2F6CU%3D&t=9276707c&ps=14f1eb3e&shp=9e36835a&shcp=317596d8&idc=my&VideoID=v10033g50000d7vgcfnog65lu32nt9gg",
        "video_url": {
          "1080p": "https://v16m-default.tiktokcdn.com/32d73d07c16e4f471e7b5d8bb918c0c3/6a2b70e3/video/tos/alisg/tos-alisg-ve-0051c001-sg/oM2FmLGUBSPePzfFmneAAcAeUigMRcRmGgCBIA/?a=0&bti=NTU4QDM1NGA%3D&&bt=3708&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=PDk0ZjZmPGY2aTNoZGk8ZEBpajxxNm85cmlqOjMzODYzNEBjXy9jL2AyNS0xNDVhY2EtYSNkcS9yMmRrYHNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e00088000",
          "360p": "https://v16m-default.tiktokcdn.com/a1876edb7df21fac9d98481f2143b9bb/6a2b70e3/video/tos/alisg/tos-alisg-ve-0051c001-sg/oEg7C2FnlffBmLR3zcfGQAAMABGeAPFPmRQSIg/?a=0&bti=NTU4QDM1NGA%3D&&bt=651&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=aWRlOWVpPGhpNThpPGU7M0BpajxxNm85cmlqOjMzODYzNEA0YGIzXmJjNi0xYTUuMy00YSNkcS9yMmRrYHNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e00088000",
          "480p": "https://v16m-default.tiktokcdn.com/b9146ce3b0343095acedca05c3b1dbfe/6a2b70e3/video/tos/alisg/tos-alisg-ve-0051c001-sg/o4FoABBf8LXYFMgAgnIGzQecRfbQAmmSGAfPR2/?a=0&bti=NTU4QDM1NGA%3D&&bt=1001&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=OWg7OTg2OzVkNTg7PDY3OkBpajxxNm85cmlqOjMzODYzNEBiYDQuLV5eNmAxLS8wLzMyYSNkcS9yMmRrYHNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e00088000",
          "540p": "https://v16m-default.tiktokcdn.com/23c3f5d3b8b994d3139eaadd322be6cf/6a2b70e3/video/tos/alisg/tos-alisg-ve-0051c001-sg/okiTaSTTRAM5gb0hAQFufBgDHfpgIQwEDGCvfI/?a=0&bti=NTU4QDM1NGA%3D&&bt=1378&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=aDZlNzY6ZGc2Nzk5ODg3O0BpajxxNm85cmlqOjMzODYzNEA2Ni4yYS8zNWExMy5fXy8vYSNkcS9yMmRrYHNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e00088000",
          "720p": "https://v16m-default.tiktokcdn.com/e4d4f3ab44663c803398debfc23dc234/6a2b70e3/video/tos/alisg/tos-alisg-ve-0051c001-sg/owgMlfBfKXi5AFAtMnmP2rAjmQA18GCMi8EeMf/?a=0&bti=NTU4QDM1NGA%3D&&bt=1998&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=Ojk4ZzU6NTY7aTUzODw7ZEBpajxxNm85cmlqOjMzODYzNEBfLzUtLjBiNTAxL2MxLWJhYSNkcS9yMmRrYHNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e00088000"
        },
        "width": 720,
        "height": 1280
      }
    },
    {
      "ad_title": "5 ADET GÖMLEK 1499 TL ÜCRETSİZ ŞEFFAF KAERGO VE KAPIDA ÖDEME İMKANIYLA SATIŞTA",
      "brand_name": "Not Mention",
      "cost": 0,
      "ctr": 0.69,
      "favorite": false,
      "id": "7638003104369262599",
      "industry_key": "label_22108000000",
      "is_search": false,
      "like": 42,
      "objective_key": "campaign_objective_conversion",
      "video_info": {
        "vid": "v14033g50000d85fgc7og65oen6roig0",
        "duration": 22.617,
        "cover": "https://p16-common-sign.tiktokcdn.com/tos-alisg-p-0051c001-sg/oEAgzCUDqBewlK4FEkzvwAI6DBtVfCBg5NQDgw~tplv-noop.image?dr=18692&refresh_token=e512f622&x-expires=1781231814&x-signature=yAU5GchbV13nDqBVB4pVb1cJOts%3D&t=9276707c&ps=14f1eb3e&shp=9e36835a&shcp=317596d8&idc=my&VideoID=v14033g50000d85fgc7og65oen6roig0",
        "video_url": {
          "1080p": "https://v16m-default.tiktokcdn.com/51d1205b8401a39117202ba794525941/6a2b70c6/video/tos/alisg/tos-alisg-ve-0051c001-sg/oQAchtKPfffR2tfGypfY0ABZAYM4ADTnhiIUgo/?a=0&bti=NTU4QDM1NGA%3D&&bt=3288&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=ODZmNWUzPGhlaGY5NTVoM0BpM2x1cXI5cmZpOzMzODYzNEAvMWFiYDE1NS0xMjMtMTUwYSNkbDNiMmQ0ZDJhLS1kMDFzcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b8000",
          "360p": "https://v16m-default.tiktokcdn.com/d8f4a417a1de53ee1475ed8c9feadbc2/6a2b70c6/video/tos/alisg/tos-alisg-ve-0051c001-sg/osp2AAAYPKoyYtftgLeoXAATZMhf4fmAUti5fD/?a=0&bti=NTU4QDM1NGA%3D&&bt=541&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=ZWg8aGg0OmU8ZzxoOWdnOEBpM2x1cXI5cmZpOzMzODYzNEA1YC0uMDRgNi8xMzM0LzEzYSNkbDNiMmQ0ZDJhLS1kMDFzcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b8000",
          "480p": "https://v16m-default.tiktokcdn.com/dd5f5f235237a87d33ae0d1bc7ea0c1e/6a2b70c6/video/tos/alisg/tos-alisg-ve-0051c001-sg/oQ5PQKFpXaggU2YfDgDAINfubSTAoCXGE6Ekfv/?a=0&bti=NTU4QDM1NGA%3D&&bt=790&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=ZDVpNGc4OGhlM2Y4ZGVnPEBpM2x1cXI5cmZpOzMzODYzNEAuLTRgLzRjNTQxYTY1MzMxYSNkbDNiMmQ0ZDJhLS1kMDFzcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b8000",
          "540p": "https://v16m-default.tiktokcdn.com/d374c16cd478aabbdf5d880ab37160d0/6a2b70c6/video/tos/alisg/tos-alisg-ve-0051c001-sg/oofbgAQMpJ8Gf5rAon0fMsUR5LWKq2AfQBFwUA/?a=0&bti=NTU4QDM1NGA%3D&&bt=1055&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=MzQ5Zjs3Ozs3ZDM5aTg8OEBpM2x1cXI5cmZpOzMzODYzNEBfYWEwLjU2Xy4xMjQ2Ly8tYSNkbDNiMmQ0ZDJhLS1kMDFzcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b8000",
          "720p": "https://v16m-default.tiktokcdn.com/aed51190bc179e4093939cc438f01338/6a2b70c6/video/tos/alisg/tos-alisg-ve-0051c001-sg/oAMQFBgAADAWUQ0oft2s5f8q0bM0GFRRfA5nJf/?a=0&bti=NTU4QDM1NGA%3D&&bt=1614&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=aDc2OGc4O2Y1Nzs0aDY7M0BpM2x1cXI5cmZpOzMzODYzNEAuYjQtXmMtNjUxYDRgMi0uYSNkbDNiMmQ0ZDJhLS1kMDFzcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b8000"
        },
        "width": 720,
        "height": 1280
      }
    },
    {
      "ad_title": "4 Adet Cepoli Polo Yaka T-Shirt 1500 TL",
      "brand_name": "",
      "cost": 0,
      "ctr": 0.74,
      "favorite": false,
      "id": "7646715882820796437",
      "industry_key": "label_22108000000",
      "is_search": false,
      "like": 105,
      "objective_key": "campaign_objective_conversion",
      "video_info": {
        "vid": "v10033g50000d8fa0uvog65g124in0kg",
        "duration": 13.634,
        "cover": "https://p16-common-sign.tiktokcdn.com/tos-alisg-p-0051c001-sg/ocsgRBo7AEBDqgQqNuSBBXJkHEQGIDFeGAbHfD~tplv-noop.image?dr=18692&refresh_token=42d1243f&x-expires=1781231805&x-signature=0yuQi8dn6Ucayr238Aussxuerm8%3D&t=9276707c&ps=14f1eb3e&shp=9e36835a&shcp=317596d8&idc=my&VideoID=v10033g50000d8fa0uvog65g124in0kg",
        "video_url": {
          "1080p": "https://v16m-default.tiktokcdn.com/23565c66c15cb9676fa863ae03beef30/6a2b70bd/video/tos/alisg/tos-alisg-ve-0051c001-sg/oIDBGUSCe88IGbLblhIWdkAgllAeUnDet4PQ6G/?a=0&bti=NTU4QDM1NGA%3D&&bt=415&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=Ozc3OGQ6Ozc1NzY5Ojc0NEBpajNsNWo5cnhkOzMzODYzNEAtYy0uX15iNjExMWFeMmM1YSNoazEuMmRzLWNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000",
          "360p": "https://v16m-default.tiktokcdn.com/9b50d0b68e5e8f424d39d0c1ca3f562c/6a2b70bd/video/tos/alisg/tos-alisg-ve-0051c001-sg/oYeBAPGGyIUzLI885geCbenW6DhalSGlAIDUFQ/?a=0&bti=NTU4QDM1NGA%3D&&bt=127&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=NDw3PDloZTNoPDc5NzU1Z0BpajNsNWo5cnhkOzMzODYzNEBfNGBhLjIvX2MxYDY0LjAuYSNoazEuMmRzLWNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000",
          "480p": "https://v16m-default.tiktokcdn.com/64521438c041873d0563174e26d30f38/6a2b70bd/video/tos/alisg/tos-alisg-ve-0051c001-sg/oIBL0IUUUQDfghl9CDLIA8GnGPAb8pbIQee8gS/?a=0&bti=NTU4QDM1NGA%3D&&bt=156&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=ODc0PDc2NTNnaDZkNzwzaUBpajNsNWo5cnhkOzMzODYzNEAvLzMtYV8uNTMxMGFiMGIyYSNoazEuMmRzLWNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000",
          "540p": "https://v16m-default.tiktokcdn.com/2f2c01fe3dcd17b2b2425660e7c552c9/6a2b70bd/video/tos/alisg/tos-alisg-ve-0051c001-sg/okgCPlBAASlG9eDbJuRb0ne8GhDL9LIUAQUI8e/?a=0&bti=NTU4QDM1NGA%3D&&bt=182&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=ZDw4ZzxkO2dkNzM6OTU7PEBpajNsNWo5cnhkOzMzODYzNEAxMF8yXjU1XzAxNTQvY15eYSNoazEuMmRzLWNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000",
          "720p": "https://v16m-default.tiktokcdn.com/7baa70f969b9d4ac75a9ca873749571c/6a2b70bd/video/tos/alisg/tos-alisg-ve-0051c001-sg/okpn8DNUQIhlPeCDSLUG9G1CPIaBg8FeAAeLYb/?a=0&bti=NTU4QDM1NGA%3D&&bt=244&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=N2hnZDg5OTdlPDw5NDo0PEBpajNsNWo5cnhkOzMzODYzNEBiMV40MzBiX2MxMjFfLmA2YSNoazEuMmRzLWNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000"
        },
        "width": 720,
        "height": 1280
      }
    },
    {
      "ad_title": "4 Adet Cepoli Polo Yaka T-Shirt 1500 TL",
      "brand_name": "",
      "cost": 0,
      "ctr": 0.73,
      "favorite": false,
      "id": "7646715904160579605",
      "industry_key": "label_22108000000",
      "is_search": false,
      "like": 76,
      "objective_key": "campaign_objective_conversion",
      "video_info": {
        "vid": "v10033g50000d8fa18nog65jnsubnjc0",
        "duration": 13.634,
        "cover": "https://p19-common-sign.tiktokcdn.com/tos-alisg-p-0051c001-sg/oM8SQwgbCGLUfQG3DcALmPKzIeolUFICnDFOeA~tplv-noop.image?dr=18692&refresh_token=6e525bb1&x-expires=1781231805&x-signature=hf06OsNvYbq67o8Fpu0rJD4w1Dk%3D&t=9276707c&ps=14f1eb3e&shp=9e36835a&shcp=317596d8&idc=my&VideoID=v10033g50000d8fa18nog65jnsubnjc0",
        "video_url": {
          "1080p": "https://v16m-default.tiktokcdn.com/0f6e12b06199e2a0d76d5e32f1407346/6a2b70bd/video/tos/alisg/tos-alisg-ve-0051c001-sg/oAgQZlr6QRqGgZPCmetM8Deb8nAWTQSA76lUIe/?a=0&bti=NTU4QDM1NGA%3D&&bt=374&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=Z2ZkODZkNDU4NzQ3OTc7N0BpM21ldm05cjtkOzMzODYzNEBhMzFfYi0xNTQxXy8wMjUyYSNga3JrMmRrLmNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000",
          "360p": "https://v16m-default.tiktokcdn.com/340c3ce7666b561533e6e23902e2a6ca/6a2b70bd/video/tos/alisg/tos-alisg-ve-0051c001-sg/o8mebSetUQg5GUDqlCPWPg8QIZMGRjArnA826e/?a=0&bti=NTU4QDM1NGA%3D&&bt=129&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=aTw2OmY5ZTQzaWQ0Z2U3M0BpM21ldm05cjtkOzMzODYzNEBiNC5iMi4vXjYxL18uLV8yYSNga3JrMmRrLmNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000",
          "480p": "https://v16m-default.tiktokcdn.com/7bb0fe7578656fca22492c4de8d2feb5/6a2b70bd/video/tos/alisg/tos-alisg-ve-0051c001-sg/oYLn8qIeQQmZmjWDSlUGeM6CPIiegrx8AARWob/?a=0&bti=NTU4QDM1NGA%3D&&bt=156&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=NmQzNzloZDU3MzY8aTtlOEBpM21ldm05cjtkOzMzODYzNEBgYi4tNjBiXzIxNF4xY2MzYSNga3JrMmRrLmNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000",
          "540p": "https://v16m-default.tiktokcdn.com/7300bbefcb6c3d80c3c1f03f3f843dba/6a2b70bd/video/tos/alisg/tos-alisg-ve-0051c001-sg/oIRrcnMnQWA8IlCPeJQgklGlDqSp8bZeUe6AAm/?a=0&bti=NTU4QDM1NGA%3D&&bt=180&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=NWdnOGlmZmk6ZWk8M2VpNEBpM21ldm05cjtkOzMzODYzNEAyNl9gXjMvXi4xYzYtYy0wYSNga3JrMmRrLmNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000",
          "720p": "https://v16m-default.tiktokcdn.com/3be4a466e5d7e2684099a0f7535d979d/6a2b70bd/video/tos/alisg/tos-alisg-ve-0051c001-sg/oAMmene8bUQRYgDOCZMer8WSZ6KPAAqQR6lXIG/?a=0&bti=NTU4QDM1NGA%3D&&bt=232&ft=cApXJCz7ThWHanz9LGZmo0P&mime_type=video_mp4&rc=OmU2Z2hkZztmPGVmOTU3N0BpM21ldm05cjtkOzMzODYzNEBgYjYtMzAyNTUxX19jMS0wYSNga3JrMmRrLmNhLS1kMC1zcw%3D%3D&vvpl=1&l=20260612043632D3452D043274878B2384&btag=e000b0000"
        },
        "width": 720,
        "height": 1280
      }
    }
  ]
}

Verify Response Structure

Check that your response includes the expected fields:

  • success(boolean)
  • credits_remaining(number)
  • ad_title(string)
  • brand_name(string)
  • comment(number)
  • ... and 24 more fields

Best Practices

1

Error Handling

Implement comprehensive error handling and retry logic for failed requests. Log errors properly for debugging.

2

Caching

Cache responses when possible to reduce API calls and improve performance. Consider data freshness requirements.

3

Security

Never expose your API key in client-side code. Use environment variables and secure key management practices.

Performance Tips

Batch Requests

When scraping multiple ads, consider batching requests to maximize throughput while staying within rate limits.

Async Processing

Use asynchronous processing in Ruby to handle multiple requests concurrently and improve overall performance.

Common Use Cases

Market Research

Analyze TikTok Ad Library ads to understand market trends, competitor analysis, and audience insights.

Content Analytics

Track performance metrics, engagement rates, and content trends across TikTok Ad Library ads.

Lead Generation

Identify potential customers and business opportunities throughTikTok Ad Library data analysis.

Troubleshooting

Common Errors

401 Unauthorized

Check your API key is correct and properly formatted in the x-api-key header.

402 Payment Required

You ran out of credits and need to buy more.

404 Not Found

The resource might not exist or be private.

500 Server Error

Temporary server issue. Implement retry logic with exponential backoff.

Frequently Asked Questions

How much does it cost to scrape TikTok Ad Library ads?

ScrapeCreators offers 100 free API calls to get started. After that, pricing starts at $10 for 5k requests with volume discounts available.

Is it legal to scrape TikTok Ad Library data?

Scraping publicly available data is fair game, and we only collect public data. So anything that you can see in an incognito browser is what we collect.

How fast can I scrape TikTok Ad Library ads?

There is no rate limit! So you can scrape as fast as you want!

What data format does the API return?

All API responses are returned in JSON format, making it easy to integrate with any programming language or application.

Can I use this with other Ruby frameworks?

Yes! This tutorial focuses on core Ruby HTTP concepts that work with any framework. The API calls remain the same regardless of your specific Ruby setup.

How do I handle large datasets?

For large datasets, implement pagination, use streaming responses where available, and consider storing data in a database for efficient querying.

Related Tutorials

Ready to ship?

Get the API key. Run the code.

100 free API calls. No credit card. Same endpoint, same response shape.

Same endpoint, different language

Pick another stack.