提问者:小点点

10k次相同URL的PHP卷曲请求


我有一个Excel文件大约。 1.29 MB,它有11500行数据。

在我的PHP代码中,我首先读取整个文件并通过PHPExcel/IOFactory库放入数组。

在put之后,在foreach循环中,我开始为curl创建$postvars。

gonderi_referans=REF&alici=Sarah&alici_telefon=55544448885&alici_adres=Krg&alici_ulke=DE

在foreach循环中,代码将创建11500次$postvars并发出curl请求。

    $url = "https://$_SERVER[HTTP_HOST]/api572.php";
    $ch = curl_init();
    curl_setopt($ch,CURLOPT_URL,$url);
    curl_setopt($ch,CURLOPT_POST, 1);          
    curl_setopt($ch,CURLOPT_POSTFIELDS,$postvars);
    curl_setopt($ch,CURLOPT_RETURNTRANSFER, true);
    curl_setopt($ch,CURLOPT_CONNECTTIMEOUT ,30);
    curl_setopt($ch,CURLOPT_TIMEOUT, 20);
    $response =json_decode(curl_exec($ch), true);

此操作大约需要5分钟。 我想以更快的方式做这件事。 我怎么能做到呢?

代码读取excel文件在10秒内,卷曲请求它需要很多次。


共1个答案

匿名用户

尝试使用一些批处理来最小化发送请求的数量,完全是基本的POC:

excel-reader.php:

    <?php

// Dummy data START
$dummyExcelRows = [];
for ($i = 0; $i <= 11500; $i++) {
    $dummyExcelRows[] = "gonderi_referans=REF&alici=Sarah&alici_telefon=55544448885&alici_adres=Krg&alici_ulke=DE&id=$i";
}
// Dummy data END

// Serialize multiple URI into one string START
$data = [];
foreach ($dummyExcelRows as $postvars) {
    $data[] = $postvars;
}
$dataToSend = ['payload' => json_encode($data)];
// Serialize multiple URI into one string END



$url = "http://$_SERVER[HTTP_HOST]/test/api572.php";
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $dataToSend);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 30);
curl_setopt($ch, CURLOPT_TIMEOUT, 20);
//    $response =json_decode(curl_exec($ch), true);
$response = curl_exec($ch);

var_dump($response);

api572.php:

<?php

$decoded = json_decode($_POST['payload']);
foreach ($decoded as $row) {
    echo "Do something with $row <br/>";
    echo '<pre>';
    parse_str($row, $fakePost);
    print_r($fakePost);
    echo '</pre>';
}