我有几张要使用Twilio发送到WhatsApp编号的图像。我只想在发送完所有图像后再发送一条短信。发送图像时,我指定了一个回调,该回调获取传送状态并使用Redis进行存储。打电话发送这些图像后,我检查所有图像的传送状态,如果所有图像的状态都不等于零,则发送文本消息,否则我进行检查,直到得到一个交货状态不为零。但是,我提出的解决方案正在超时。我收到此错误-Maximum execution time of 60 seconds exceeded from Redis
即使图像未发送。见所附图片
这是我在做什么:
Route::get('test', function (){
$redis = new \Predis\Client();
$images = \App\ProductImage::where('product_id', 7)->get();
foreach ($images as$image){
$imgUrl = url(env('BOT_URL').'/images/'.$image['img_url']);
$sid[] = \App\Libraries\Utilities::sendMediaMessage('+23xxxxx', '', $imgUrl);
}
foreach ($sid as $id){
$statuses[] = $redis->get($id);
}
if(in_array(0, $statuses)){
$check = \App\Libraries\Utilities::checkIfWhatsAppStatusHasChanged($sid);
if ($check){
\App\Libraries\Utilities::sendWhatsAppMessage('+23xxxxx', 'Send message - had to check');
}
}else{
\App\Libraries\Utilities::sendWhatsAppMessage('+23xxxx', 'Send message ');
}
});
这里是sendMediaMessage方法
public static function sendMediaMessage($phone, $msg, $mediaUrl){
try{
$client = new Client(env('TWILIO_SID'), env('TWILIO_TOKEN'));
$send = $client->messages->create(
"whatsapp:".$phone, // Text this number
array(
'from' => "whatsapp:".env('TWILIO_NUMBER'), // From a valid Twilio number
'body' => $msg,
'mediaUrl' => $mediaUrl,
'statusCallback' => url(env('BOT_URL').'/whatsapp-delivery-status')
)
);
//
if($send != false){
$message_sid = $send->sid;
return $message_sid;
}
}catch (\Exception $exception){
}
}
这里是回调方法-
public function checkWhatsapDelivery(Request $request)
{
$redis = new Client();
$body = $request->all();
$messageSid = $body['MessageSid'];
$MessageStatus = $body['MessageStatus'];
$status_id = Utilities::getWhatsappMessageStatus($MessageStatus);
$redis->set($messageSid, $status_id);
}
这里是getWhatsappMessageStatus方法
public static function getWhatsappMessageStatus($status){
switch (strtolower($status)){
case 'queued':
$id = 1;
break;
case 'failed':
$id = 2;
break;
case 'sent':
$id = 3;
break;
case 'delivered':
$id = 4;
break;
case 'read':
$id = 5;
break;
default:
$id = 0;
}
return $id;
}
这里是checkIfWhatsAppStatusHasChanged方法
public static function checkIfWhatsAppStatusHasChanged($sids){
$statuses = self::getWhatsAppStatuses($sids);
if(in_array(0, $statuses)){
self::checkIfWhatsAppStatusHasChanged($sids);
}else{
return true;
}
}
这里是getWhatsAppStatuses方法
public static function getWhatsAppStatuses($sids){
$redis = new \Predis\Client();
foreach ($sids as $id){
$statuses[] = $redis->get($id);
}
return $statuses;
}
请问我做错了什么?
检查Linux中php.ini
(windows)和C:\xampp\php\php.ini
中的opt/lampp/etc/php.ini
文件。默认情况下,这是max_execution_time = 60秒。因此,您必须增加max_execution_time才能发送/发布大尺寸数据。