Tout a commencé avec le fait que je voulais faire une chaîne sur instagram toute la journée à rechercher et tester des services de publication automatique, puis j'ai décidé de regarder des packages github prêts à l'emploi, j'ai été surpris par la taille du code de ces packages (certains frameworks php sont plus petits que ces wrappers sur instagram), J'ai craché et j'ai décidé d'écrire mon emballage avec des fonctionnalités minimales.S'identifier
Nous passerons l'autorisation via la version WEB. Pour ce faire, nous aurons besoin dès le début d'obtenir des en-têtes, des cookies.
$curl = curl_init();
curl_setopt_array($curl, [
CURLOPT_URL => 'https://www.instagram.com/',
CURLOPT_HEADER => true,
CURLOPT_SSL_VERIFYHOST => false,
CURLOPT_SSL_VERIFYPEER => false,
CURLOPT_RETURNTRANSFER => true,
CURLINFO_HEADER_OUT => true,
CURLOPT_HTTPHEADER => ['user-agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64)
AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.130 Safari/537.36'],
]);
$response = curl_exec($curl);
$headers = curl_getinfo($curl);
$header_content = substr($response, 0, $headers['header_size']);
curl_close($curl);
$cookie = [];
preg_match_all("/Set-Cookie:\s*(?<cookie>[^=]+=[^;]+)/mi", $header_content, $matches);
foreach ($matches['cookie'] as $c) {
if ($c = str_replace(['sessionid=""', 'target=""'], '', $c)) {
$c = explode('=', $c);
$cookie = array_merge($cookie, [trim($c[0]) => trim($c[1])]);
}
}
if (isset($cookie['csrftoken']) {
}
De plus, je ne donnerai pas d'exemples du travail de CURL.Autorisation:
POST
https:
HEADER
Content-Type: application/x-www-form-urlencoded
x-ig-app-id: 1217981644879628
x-csrftoken:
cookie:
user-agent:
BODY
username=&password=&queryParams={}&optIntoOneTap=false
{"authenticated": true, "user": true, "userId": "****", "loginNonce": "****", "reactivated": true, "status": "ok"}
{"authenticated": false, "user": true, "status": "ok"}
Recherche d'utilisateurs
Pour ce faire, nous aurons besoin des cookies précédemment reçus et de l'en-tête x-csrftoken.
GET
https:
HEADER
x-csrftoken:
x-ig-app-id: 1217981644879628
cookie:
user-agent:
{
"users": [
{"position":0,
"user":{
"pk":" "
"username":" "
"full_name":" , "
.....
}
},{},{}
],
"places":[ ],
"hashtags":[ ],
"has_more": true,
"rank_token": "0.44093530619864296",
"clear_client_cache": false,
"status: "ok"
}
Envoi de messages à diriger
Pour envoyer des messages à diriger, nous avons besoin d'un identifiant à qui nous enverrons, comment trouver les utilisateurs que j'ai décrits ci-dessus.
POST
https:
HEADER
user-agent: Instagram 10.2.2 Android (18/4.3; 320dpi; 720x1280; Huawei; HWEVA; EVA-L18; qcom; en_US)
x-csrftoken:
x-ig-app-id: 1217981644879628
cookie:
content-type: application/x-www-form-urlencoded
BODY
text={ }&_uuid=&_csrftoken={ csrftoken}&recipient_users="[[ ]]"&action=send_item&thread_ids=["0"]&client_context={UUID v4 }
{"status":"ok", "payload":{"item_id":" "} ...}
function uuid4()
{
if (function_exists('com_create_guid') === true) {
return trim(com_create_guid(), '{}');
}
$data = openssl_random_pseudo_bytes(16);
$data[6] = chr(ord($data[6]) & 0x0f | 0x40);
$data[8] = chr(ord($data[8]) & 0x3f | 0x80);
return vsprintf('%s%s%s%s%s%s%s%s', str_split(bin2hex($data), 4));
}
Téléchargement de photos via la version WEB
Avant d'envoyer des images, vous devez les enregistrer en qualité ImageJPEG 100 sinon l'instagram retournera une erreur:$photo = __DIR__ . '/source.jpg';
$file_temp = __DIR__ . '/send_images.jpg';
list($width, $height, $image_type) = getimagesize(realpath($photo));
$srcImage = ImageCreateFromJPEG($photo);
$resImage = ImageCreateTrueColor($width, $height);
ImageCopyResampled($resImage, $srcImage, 0, 0, 0, 0, $width, $height, $width, $height);
ImageJPEG($srcImage, $file_temp, 100);
ImageDestroy($srcImage);
Envoyer la photo:
$microtime = round(microtime(true) * 1000);
POST
https:
HEADER
content-type: image/jpg
x-entity-name: 'fb_uploader_' . $microtime
offset: 0
user-agent: Mozilla/5.0 (iPhone; CPU iPhone OS 11_4_1 like Mac OS X; ru-RU) AppleWebKit/537.36 (KHTML, like Gecko) Version/11.4.1 Mobile/15G77 Safari/537.36 Puffin/5.2.2IP
x-entity-length: filesize($file_temp)
x-instagram-rupload-params: {"media_type":1,"upload_id":"' . $microtime . '","upload_media_height":' . $height . ',"upload_media_width":' . $width . '}
x-csrftoken:
x-ig-app-id: 1217981644879628
cookie:
BODY
file_get_contents(realpath($file_temp))
{"upload_id":" $microtime", "status":"ok" ...}
POST
https:
HEADER
content-type: application/x-www-form-urlencoded
user-agent: Mozilla/5.0 (iPhone; CPU iPhone OS 11_4_1 like Mac OS X; ru-RU) AppleWebKit/537.36 (KHTML, like Gecko) Version/11.4.1 Mobile/15G77 Safari/537.36 Puffin/5.2.2IP
x-csrftoken:
x-ig-app-id: 1217981644879628
cookie:
BODY
upload_id=$microtime&caption={, }&usertags=&custom_accessibility_caption=&retry_timeout=
{"status":"ok", "media":{"id":"***", ...}}
C'est tout, j'ai implémenté un wrapper minimal sur instagram.J'ai posté la version de travail complète sur github .
Je serai heureux d'entendre parler de la mise en œuvre, peut-être quelque chose que j'ai mal fait.