Files
tougao/application/api/job/RelatedArticle.php
2025-06-05 17:37:47 +08:00

61 lines
2.4 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?php
namespace app\api\job;
use think\queue\Job;
use app\common\QueueJob;
use app\common\JournalArticle;
class RelatedArticle
{
// 相关文章发送邮件任务
public function fire(Job $job, $data)
{
//获取任务ID
$iLogId = 0;
try {
//实例化
$oQueueJob = new QueueJob;
$sMsg = '获取相关文章信息成功';
if(!empty($job->getRawBody())){
$aJob = json_decode($job->getRawBody(), true);
$aParam = [
'job_id' => empty($aJob['id']) ? '' : $aJob['id'],
'job_class' => get_class($this),
'status' => 0,
'create_time' => time(),
'params' => json_encode($aJob, JSON_UNESCAPED_UNICODE)
];
$iLogId = $oQueueJob->addLog($aParam);
// 步骤1上传素材图片
$iArticleId = empty($data['article_id']) ? 0 : $data['article_id'];
if (!empty($iArticleId)) {
//上传素材
$oJournalArticle = new JournalArticle;
$aResult = json_decode(JournalArticle::get($data),true);
$iStatus = empty($aResult['status']) ? 0 : $aResult['status'];
$sMsg = empty($aResult['msg']) ? '获取相关文章信息失败' : $aResult['msg'];
}
}
$job->delete();
//更新任务状态
$aParam = ['log_id' => $iLogId,'status' => 1,'update_time' => time(),'error' => $sMsg];
$oQueueJob->updateLog($aParam);
// // 记录日志
// \think\Log::info("RelatedArticle延迟任务执行成功: ".json_encode($data));
} catch (\Exception $e) {
//实例化
$oQueueJob = new QueueJob;
//更新任务状态
$sMsg = empty($e->getMessage()) ? '任务出错' : $e->getMessage();
$aParam = ['log_id' => $iLogId,'status' => 2,'update_time' => time(),'error' => $sMsg];
$oQueueJob->updateLog($aParam);
$job->delete();
// // 记录错误日志
// \think\Log::error("RelatedArticle延迟任务失败: ".$e->getMessage());
}finally {
gc_collect_cycles(); // 强制垃圾回收
}
}
}