mamadogroup/

instagram-php-scraper

Instagram PHP 爬虫。无需任何授权即可获取账户信息、照片和视频

v0.12.7 2022-09-01 09:39 UTC

This package is auto-updated.

Last update: 2024-09-05 20:00:28 UTC


README

这个库基于 Instagram 网页版。我们开发它是因为现在很难获得一个经过批准的 Instagram 应用程序。目的是支持网页桌面版和移动版支持的所有功能。

依赖项

代码示例

use Phpfastcache\Helper\Psr16Adapter;

$instagram = \InstagramScraper\Instagram::withCredentials(new \GuzzleHttp\Client(), 'username', 'password', new Psr16Adapter('Files'));
$instagram->login();
$account = $instagram->getAccountById(3);
echo $account->getUsername();

一些方法不需要认证

$instagram = new \InstagramScraper\Instagram(new \GuzzleHttp\Client());
$nonPrivateAccountMedias = $instagram->getMedias('kevin');
echo $nonPrivateAccountMedias[0]->getLink();

如果您使用认证,建议缓存用户会话。在这种情况下,您不需要每次程序运行时都运行 $instagram->login() 方法

use Phpfastcache\Helper\Psr16Adapter;

$instagram = \InstagramScraper\Instagram::withCredentials(new \GuzzleHttp\Client(), 'username', 'password', new Psr16Adapter('Files'));
$instagram->login(); // will use cached session if you want to force login $instagram->login(true)
$instagram->saveSession();  //DO NOT forget this in order to save the session, otherwise have no sense
$account = $instagram->getAccountById(3);
echo $account->getUsername();

使用代理请求

// https://docs.guzzlephp.org/en/stable/request-options.html#proxy
$instagram = new \InstagramScraper\Instagram(new \GuzzleHttp\Client(['proxy' => 'tcp://:8125']));
// Request with proxy
$account = $instagram->getAccount('kevin');
\InstagramScraper\Instagram::setHttpClient(new \GuzzleHttp\Client());
// Request without proxy
$account = $instagram->getAccount('kevin');

安装

使用 composer

composer.phar require raiym/instagram-php-scraper phpfastcache/phpfastcache

composer require raiym/instagram-php-scraper phpfastcache/phpfastcache

如果您没有 composer

您可以在此下载

示例

请参阅示例 此处

其他

Java 库: https://github.com/postaddictme/instagram-java-scraper