Unofficial TikTok API for PHP
composer require ssovit/tiktok-api
It's available on monthly subscription. See below for plans and contact details.
Follow examples in /example
directory
$api=new \Sovit\TikTok\Api(array(/* config array*/));
$trendingFeed=$api->getTrendingFeed($maxCursor=0);
$userData=$api->getUser("tiktok");
$userFeed=$api->getUserFeed("tiktok",$maxCursor=0);
$challenge=$api->getChallenge("foryourpage");
$challengeFeed=$api->getChallengeFeed("foryourpage",$maxCursor=0);
$musc=$api->getMusic("6798898508385585925");
$musicFeed=$api->getMusicFeed("6798898508385585925",$maxCursor=0);
$videoData=$api->getVideoByID("6829540826570296577");
$videoData=$api->getVideoByUrl("https://www.tiktok.com/@zachking/video/6829303572832750853");
$noWatermark=$api->getNoWatermark("https://www.tiktok.com/@zachking/video/6829303572832750853");
$api=new \Sovit\TikTok\Api(array(
"user-agent" => 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/83.0.4103.106 Safari/537.36', // Valid desktop browser HTTP User Agent
"proxy-host" => false,
"proxy-port" => false,
"proxy-username" => false,
"proxy-password" => false,
"cache-timeout" => 3600 // 1 hours cache timeout
"cookie_file" => sys_get_temp_dir() . 'tiktok.txt', // cookie file path
"nwm_endpoint" => "https://my-api.example.com" // private api endpoint
"api_key" => "API_KEY" // see below on how to get API key
), $cache_engine=false);
You can build your own engine that will store and fetch cache from your local storage to prevent frequent requests to TikTok server. This can help being banned from TikTok server for too frequent requests.
Cache engine should have callable get
and set
methods that the API class uses
// Example using WordPress transient as cache engine
Class MyCacheEngine{
function get($cache_key){
return get_transient($cache_key);
}
function set($cache_key,$data,$timeout=3600){
return set_transient($cache_key,$data,$timeout);
}
}
Usage
$cache_engine=new MyCacheEngine();
$api=new \Sovit\TikTok\Api(array(/* config array*/),$cache_engine);
Follow examples on /example
folder for video stream and download example
Note: TikTok videos will not play directly when used in HTML video player as they require www.tiktok.com
as http referrer.
To use proxy, provide proxy-host
, proxy-port
, proxy-username
, proxy-password
It's highly recommended that you use proxy to prevent your IP from getting banned.
It's highly recommended to use Rotating
Proxy service if you are making lots of requests in short interval of time. Webshare.io Proxy Service is good. It's my referral link and I would get a bit from it
getTrendingFeed
- Get trending feedgetTrendingFeed($maxCursor)
getUser
- Get profile data for TikTok UsergetUser($username)
getUserFeed
- Get user feed by IDgetUserFeed($user_id,$maxCursor)
getUserFeedByName
- Get user feed by NamegetUserFeedByName($username,$maxCursor)
getChallenge
- Get challenge/hashtag infogetChallenge($challenge)
getChallengeFeed
- Get challenge feed by IDgetChallengeFeed($challenge_id, $maxCursor)
getChallengeFeedByName
- Get challenge feed by namegetChallengeFeedByName($challenge,$maxCursor)
getMusic
- Get music infogetMusic($music_id)
getMusicFeed
- Get music feedgetMusicFeed($music_id,$maxCursor)
getVideoByID
- Get video by IDgetVideoByID($video_id)
getVideoByUrl
- Get video by URLgetVideoByUrl($video_url)
getNoWatermark
- Get no watermark for video by URLgetNoWatermark($video_url)
(only works for videos before 28th July 2020). Private API server availbale on subscription that works for all TikTok posts
$maxCursor
defaults to 0
, and is offset for results page. maxCursor
for next page is exposed on current page call feed data.
- Save the Universe
- SOCKS proxy support
- Multiple proxy support (taking turns in round-robin. Act as rotating proxy)
TikTok videos don't have video id as meta data on watermarked video posted after ~24-28 July 2020. Check below for subscription plans for non watermarked video API.
Package | Cost(per month) | Quota(requests per day) |
---|---|---|
Pro (popular) | 50 USD | 5,000 |
Mega | 100 USD | 12,000 |
Ultra | custom pricing | ? |
Source code for TikTok Mobile App API available.
Available variations
- PHP (standalone version with no external dependency)
- NodeJs (standalone version with no external dependency)
https://github.com/ssovit/TikTok-Private-API-PHP
Use issues ticket if you have questions regarding this library. Only inquiries regarding private API or custom works will be responded.
- Telegram https://t.me/ssovit
- WhatsApp https://wa.link/odwv3x
- Discord https://discord.gg/rSQd2QAXA8
- Email sovit.tamrakar@gmail.com
Use proxy. You are making too many API requests in short interval of time. Rotating proxy is recommended.
Don't hesitate to create pull requests.
TikTok is always updating their API endpoints but I will try to keep this library whenever possible. I take no responsibility if you or your IP gets banned using this API. It's recommended that you use proxy.