Youtube PHP APi 检查视频是否重复
您好,我正在使用 Google PHP API 上传 PHP 视频.我遵循了本教程 来实现这一点,它工作正常.但是如果视频已经存在于我的频道中,它也会返回视频详细信息,但我找不到它因重复而被拒绝.
Hi I am using Google PHP API to upload video in PHP. I have followed this tutorial to implement this and it is working fine. But there is a problem if video is already exist in my channel it is also returning the video details and I can't find it is a rejected for duplicate.
所以我找不到这是一个重复的视频,如果它是重复的,那么主视频是什么.表示主视频的视频详细信息,从中将其作为副本进行比较.
So I cant find this is a duplicate video or not and if it is duplicate then what is the main video. Means the video details of main video from which it is compared as duplicate.
请帮我看看这是不是重复的视频?
Please help me to find this is a duplicate video or not?
推荐答案
我能想到的检查视频状态的唯一解决方案是使用表中的字段来标记视频是否已处理.然后将 cron 设置为每小时(或您想要的频率)运行以检查视频状态.
The only solution I could come up with to check the video status is to use a field in the table to mark the video as processed or not. Then set a cron to run every hour (or however often you want) to check the video status.
我的videos
表中的字段是processed
.NULL 表示未处理,0 表示已处理.我的 api
字段以 json 格式存储 YouTube 的视频 ID.
The field in my videos
table is processed
. NULL for not processed, 0 if it's processed.
My api
field stores the YouTube's video ID in json format.
这是我的 cron 脚本:
Here's my cron script:
# Starts the YouTubeService.
$youtube_obj=new Google_Service_YouTube($client);
# Get new uploaded videos from the database.
$unprocessed_videos=$db->get_results('SELECT `id`, `file_name`, `contributor`, `api` FROM `'.DBPREFIX.'videos` WHERE `processed` IS NULL');
# If there are new videos...
if($unprocessed_videos>0)
{
# Loop through the new videos
foreach($unprocessed_videos as $new_video)
{
# Has the video been processed? Default is TRUE. will be changed to FALSE if the video still has "uploaded" status.
$video_processed=TRUE;
# Decode the `api` field.
$api_decoded=json_decode($new_video->api);
# Get the YouTube Video ID.
$video_yt_id=$api_decoded->youtube_id;
if(isset($new_video->file_name))
{
# Set the path to the video on the server.
$video_path='videos'.DS.$new_video->file_name;
}
$to='uploaders email';
$reply_to='whomever';
$subject="Video status from ".DOMAIN_NAME;
$body='';
# Check the video status.
$check_status=$youtube_obj->videos->listVideos('status', array('id' => $video_yt_id));
# Did YouTube return results?
if(!empty($check_status['items']))
{
# Loop through the videos from YouTube.
foreach($check_status['items'] as $status)
{
if($status['status']['uploadStatus']=="uploaded")
{
# The video has not been processed yet so do not send an email.
$video_processed=FALSE;
}
# Check to see if the YouTube upload was a success.
elseif($status['status']['uploadStatus']=="processed")
{
# Tell the user the video was uploaded.
$body.='Your video has been uploaded to YouTube and can be viewed at http://'.FULL_DOMAIN.'media/videos/?video='.$new_video->id;
}
# Check if the uploaded video status is rejected.
elseif($status['status']['uploadStatus']=="rejected")
{
if(isset($new_video->file_name))
{
# Get the Upload class.
require_once 'Form'.DS.'Upload.php');
# Instantiate an Upload object.
$upload_obj=new Upload($video_path);
# Delete video file from server.
$upload_obj->deleteFile($video_path);
# Delete rejected video from YouTube
$delete_response=$youtube_obj->videos->delete($video_yt_id);
}
# Need to delete the entry from the database as well.
$db->query('DELETE FROM `'.DBPREFIX.'videos` WHERE `id` = '.$db->quote($new_video->id).' LIMIT 1');
# Check if the rejection status was a duplicate.
if($status['status']['rejectionReason']=="duplicate")
{
# Tell the user the video was a duplicate.
$body.='Your video was rejected because it was a duplicate video';
}
}
}
}
else
{
$body.='Your video was not found on YouTube';
$video_processed=TRUE;
}
# Update database if the video has been "processed".
if($video_processed===TRUE)
{
# Get the Email class.
require_once 'Email'.DS.'Email.php');
# Instantiate a new Email object.
$mail_obj=new Email();
$mail_obj->sendEmail($subject, $to, $body, $reply_to);
# Set video to processed.
$db->query('UPDATE `'.DBPREFIX.'videos` SET `processed` = 0 WHERE `id` = '.$db->quote($new_video->id).' LIMIT 1');
}
}
}
相关文章