orsif/instagram-without-api

A simple PHP code to get unlimited instagram public pictures (users and tags) without api, without credentials (just token from cookies), just Instagram Scraping (with cookie and image data in base64).

v1.0.1 2023-04-25 13:50 UTC

This package is not auto-updated.

Last update: 2024-11-19 00:44:47 UTC


README

Instagram moved the pictures array to another endpoint (with more than one redirect) making harder to catch images server side without scrapers like Puppeter.

Althought is not perfect sniffagram (as a temporary solution) works.

Maybe in the future I will share a new version, but judging by the many demands without any kind of gratitude and collaboration from the community, I have lost the desire.

instagram-without-api

Instagram Without APIs

Instagram Scraping (@users and #tags) in April 2023, no credentials required


This is a PHP library, are you looking for the same in Node.js? go to https://orsi.me/instagram-without-api/.

A simple PHP code to get unlimited instagram public pictures by every user without api, without credentials (just token from cookies), just Instagram Scraping in 2023 (with cookie and image data in base64).

You can get the latest pictures/information from an account or a single picture/information by id.

đŸ“Ļ Packagist link

🛕 Cool Project Example sniffagram

🎮 Demo / Example

⚖ī¸ Licensed under MIT

🤓 Author @orsifrancesco

☕ Coffees are welcome (in particular if you appreciate the project or you plan to contact me)

đŸ“Ļ Installation from Composer Repository

composer require orsifrancesco/instagram-without-api

đŸ“Ļ Installation from this Repository

composer install

# download the file https://github.com/orsifrancesco/instagram-without-api/blob/master/test.php
# add your cookie, user-agent and x-ig-app-id following the next step "How to get Instagram Cookie"

php test.php

đŸĒ How to get Instagram Cookie

  • Login to Instagram
  • Go to your https://instagram/yourUsername
  • Open your Browser Console (on Chrome just pressing F12)
    1. Select the "Network" tab
    2. Search and click on "timeline/" file; if it is empty just refresh the page
    3. Select "Headers" bar
    4. Be sure the file is Request Method "POST" (if it is "OPTIONS" search the other "timeline/" file in the list)
    5. Scroll down and select "Request Headers" tab
    6. Copy all the code after the word "cookie: " and paste it on $cookie variable
    7. Copy all the code after the word "user-agent: " and paste it on $userAgent variable
    8. Copy all the code after the word "x-ig-app-id: " and paste it on $xIgAppId variable
- don't share your cookie code with anyone!!! it is the same of your credentials
  • That's it, enjoy :)

follow this steps

đŸ’ģ Images Base64

Although you can get the URLs of the images, Instagram doesn't give you the possibility to include and showing those images on your projects (they will be automatically blocked from their servers).
To solve this problem you will get all the URLs and all the images data in base64.
You can easily show the image data on your project with the following snippets of code:

<img src="data:image/jpg;base64, hereYourBase64String.."/>
.example { background-image: url('data:image/jpg;base64, hereYourBase64String..'); }

Check https://orsifrancesco.github.io/instagram-without-api/how-to-show-base64-images.html for Base64 example.

🛕 Cool Project Example

sniffagram

🎮 Demo / Example

example on https://github.com/orsifrancesco/instagram-without-api/blob/master/test.php

<?php

require_once __DIR__ . '/vendor/autoload.php';  // Autoload files using Composer autoload

use InstagramWithoutApi\Fetch;

$cookie = 'mid=YYcwjgAL....8765"';              // <!-- required!! please get your cookie from your browser console (6)
$userAgent = 'Mozilla/5.0...Chrome/537.36';     // <!-- required!! please get your user-agent from your browser console (7)
$xIgAppId = '9366197...';                       // <!-- required!! please get your x-ig-app-id from your browser console (8)



// get the latest 12 feeds from a tag (example https://instagram.com/explore/tags/love)

echo Fetch::fetchByTag([

  "group" => 'recent',                      // <!-- "recent" images or "top" images; "recent" is by default 
  "base64images" => true,                   // <!-- optional, but without you will be not able to save images.. it increases the size of the json file
  "base64imagesCarousel" => false,          // <!-- optional but not recommended, it increases the size of the json file
  "base64videos" => false,                  // <!-- optional but not recommended, it increases the size of the json file

  "header" =>                                   
    'cookie: ' . $cookie . "\r\n" .
    'user-agent: ' . $userAgent . "\r\n" .
    'x-ig-app-id: ' . $xIgAppId . "\r\n" .
    '',

  "maxImages" => 4,                         // <!-- optional, 12 is the max number
  "file" => "instagram-cache-bytag.json",   // <!-- optional, instagram-cache.json is by default
  "time" => 3600,                           // <!-- optional, reload contents after 3600 seconds by default
  "pretty" => true,                         // <!-- optional, prettyfy json true/false

  "id" => "love",                           // <!-- id is required

]);



// get the latest 12 pictures from an account (example https://www.instagram.com/orsifrancesco/)

echo Fetch::fetch([

  "base64images" => true,                   // <!-- optional, but without you will be not able to save images.. it increases the size of the json file
  "base64imagesCarousel" => false,          // <!-- optional but not recommended, it increases the size of the json file
  "base64videos" => false,                  // <!-- optional but not recommended, it increases the size of the json file

  "header" =>                                   
    'cookie: ' . $cookie . "\r\n" .
    'user-agent: ' . $userAgent . "\r\n" .
    'x-ig-app-id: ' . $xIgAppId . "\r\n" .
    '',

  "maxImages" => 4,                           // <!-- optional, 12 is the max number
  "file" => "instagram-cache.json",           // <!-- optional, instagram-cache.json is by default
  "time" => 3600,                             // <!-- optional, reload contents after 3600 seconds by default
  "pretty" => true,                           // <!-- optional, prettyfy json true/false

  "id" => "orsifrancesco",                    // <!-- id is required

]);



// get picture and info from instagram id url (example https://www.instagram.com/p/Cgczi6qMuh1/)

echo Fetch::fetchByIdUrl([

  "header" =>                                   
    'cookie: ' . $cookie . "\r\n" .
    'user-agent: ' . $userAgent . "\r\n" .
    'x-ig-app-id: ' . $xIgAppId . "\r\n" .
    '',

  "file" => "instagram-cache-byidurl.json",   // <!-- optional, instagram-cache-byidurl-{id}.json is by default
  "time" => 3600,                             // <!-- optional, reload contents after 3600 seconds by default
  "pretty" => true,                           // <!-- optional, prettyfy json true/false

  "id" => "Cgczi6qMuh1",                      // <!-- id is required

]);



// get picture and info from instagram id (2898553675947377985 is the id of https://www.instagram.com/p/Cgczi6qMuh1/)

echo Fetch::fetchById([

  "base64images" => true,                   // <!-- optional, but without you will be not able to save images.. it increases the size of the json file
  "base64videos" => false,                  // <!-- optional but not recommended, it increases the size of the json file

  "header" =>                                   
    'cookie: ' . $cookie . "\r\n" .
    'user-agent: ' . $userAgent . "\r\n" .
    'x-ig-app-id: ' . $xIgAppId . "\r\n" .
    '',

  "file" => "instagram-cache-byid.json",    // <!-- optional, instagram-cache-byid-{id}.json is by default
  "time" => 3600,                           // <!-- optional, reload contents after 3600 seconds by default
  "pretty" => true,                         // <!-- optional, prettyfy json true/false

  "id" => "2890411760684296309",            // <!-- id is required

]);

?>

🕹ī¸ JSON outputs

output example for Fetch::fetchByTag or Fetch::fetch on https://github.com/orsifrancesco/instagram-without-api/blob/master/instagram-cache.json

[
  {
    "id": "2696840872190940431",
    "time": 1635708506,
    "imageUrl": "https://scontent-lcy1-1.cdninstagram.com/v/t51.2885-15/e35/p1080x1080/249938862_1214260935751176_32...",
    "likes": 18,
    "comments": 0,
    "link": "https://www.instagram.com/p/CVtGnwashUP/",
    "text": "#helloworld #domain #check",
    "image": "/9j/4AAQSkZJRgABAQAAAQABAAD/7QB8UGhvdG9zaG9wIDMuMAA4QklNBAQAAAAAAGA.............",
    "location": "Liverpool Cathedral",
    "carousel": [
      {
        "imageUrl": "https://scontent.cdninstagram.com/v/t51.2885-15/314902884_370847155226583_8126....",
        "image": "/9j/4AAQSsasaakZJRgABAQAAAQABAAD/7QB8UGhvdGQAAAAAAGA............."
      },
      {
        "imageUrl": "https://scontent.cdninstagram.com/v/t51.2885-15/314674373_678631710324...",
        "image": "/9j/4AAQSkZJRgABAQAAAQdG9zaG9wIDMuMAA4QklNBAQAAAAAAGA............."
      }
    ]
  },
  {
    "id": "2654027113529608497",
    "time": 1630604708,
    "imageUrl": "https://scontent-lcy1-1.cdninstagram.com/v/t51.2885-15/e35/p1080x1080/241221239_8640769...",
    "videoUrl": "https://scontent-lcy1-1.cdninstagram.com/v/t51.2885-15/e35/p1080x1080/241221239_8640769...",
    "likes": 38,
    "comments": 0,
    "link": "https://www.instagram.com/p/CTU_5keMAkx/",
    "text": "#london #uk #unitedkingdom #tube #underground #overground #sunrise #morning #morningvibes #sky #metro #line #prospective",
    "image": "/9j/4AAQSkZJRgABAQAAAQABAAD/7QB8UGhvdG9zaG9wIDMuMAA4Qkl...........",
    "location": "Eiffle Tower, Paris France."
  }
]

output example for Fetch::fetchByIdUrl or Fetch::fetchById

[
  {
    "id": "289855367...",
    "width": 1385,
    "height": 1731,
    "imageUrl": "https:\/\/scontent-lhr8-1.cdnin...",
    "time": 1659754546,
    "topLikers": [
        "franko"
    ],
    "likes": 32,
    "commentCount": 2,
    "comments": [
      {
        "time": 1659756069,
        "text": "This is a comment...",
        "user": {
          "username": "test",
          "fullName": "DearTest",
          "imageUrl": "https:\/\/scontent-lhr8-1.cdninstagram.com..."
        }
      }
    ],
    "link": "https:\/\/www.instagram.com\/p\/Cgczi6qMuh1\/",
    "text": "If you know it, you know it...",
    "user": {
      "username": "orsifrancesco",
      "fullName": "Frank",
      "imageUrl": "https:\/\/scontent-lhr8-1.cd..."
    },
    "image": "\/9j\/4AAQSkZJR....Q=="
  }
]

⚖ī¸ License

Licensed under MIT

☕ About

Any feedback to @orsifrancesco and coffees are welcome :)