Php 通过Instagram API请求在用户之间循环真的很慢
我试图循环查看用户ID列表,以检查用户的关系状态。 这(将循环限制为20)需要足够长的时间才能得到“致命的PHP无法在30秒内处理错误”。 …我想重复20次以上 有没有办法提出“批量”请求?向IG发送我想一次签入的所有用户ID的列表 以下是我当前的片段:Php 通过Instagram API请求在用户之间循环真的很慢,php,performance,instagram,Php,Performance,Instagram,我试图循环查看用户ID列表,以检查用户的关系状态。 这(将循环限制为20)需要足够长的时间才能得到“致命的PHP无法在30秒内处理错误”。 …我想重复20次以上 有没有办法提出“批量”请求?向IG发送我想一次签入的所有用户ID的列表 以下是我当前的片段: <?php $i = 0; foreach(get_user_meta($user_id, 'followed_users', false) as $followed){ if($i < 20){
<?php
$i = 0;
foreach(get_user_meta($user_id, 'followed_users', false) as $followed){
if($i < 20){
//Makes sure it's a real Insta user ID
if(strlen($followed) > 2){
$relationshipInfo = $instagram->getUserRelationship($followed);
$relationship = $relationshipInfo->data->outgoing_status;
if( $relationship == 'none' ){
//BAN THEM
update_user_meta($user_id, 'is_banned', 1);
if(!is_page('banned') && (get_user_meta($user_id, 'is_banned', true) == 1)){
//REDIRECT TO 'BANNED' PAGE
$redirect = get_bloginfo("url").'/banned/';
wp_redirect( $redirect );
exit;
}
} else {
//DON'T BAN
update_user_meta($user_id, 'is_banned', 0);
}
}
}
$i++;
}
?>
按顺序执行请求将比并行执行请求花费更长的时间。您需要执行并发请求以加快速度 看看如何使用
$insta_id = get_user_meta($current_user->ID, 'instagram_id', true);
$fObject = $instagram->getUserFollows($insta_id, -1);
$fUsers = $fObject->data;
//generate array of users currently followed
$fArray = array();
foreach ($fUsers as $fUser) {
$fArray[] = $fUser->id;
}
//list of people followed through insta-hashtag
$wasFolloweds = get_user_meta($current_user->ID, 'followed_users', false);
foreach ($wasFolloweds as $wasF) {
//check if they unfollowed
if(strlen($wasF) > 2){
if(!in_array($wasF, $fArray)){
$userinfo = $instagram->getUserRelationship($wasF);
if(!$userinfo->meta->error_type == 'APINotAllowedError'){
//BAN THEM
update_user_meta($user_id, 'is_banned', 1);
if(!is_page('banned') && (get_user_meta($current_user->ID, 'is_banned', true) == 1)){
//REDIRECT TO 'BANNED' PAGE
$redirect = get_bloginfo("url").'/banned/';
wp_redirect( $redirect );
exit;
}
} else {
//DON'T BAN
update_user_meta($user_id, 'is_banned', 0);
}
} else {
//DON'T BAN
update_user_meta($user_id, 'is_banned', 0);
}
}
}