From fac5f17f778c34bd5fd81634304fe55d226fee6f Mon Sep 17 00:00:00 2001 From: liuwei Date: Thu, 15 May 2025 17:24:48 +0800 Subject: [PATCH] =?UTF-8?q?=E8=A7=86=E9=A2=91=E5=8A=9F=E8=83=BD=E4=BC=98?= =?UTF-8?q?=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- plugins/video/main.py | 40 +++++++++++++++++++++++++++++++++++----- 1 file changed, 35 insertions(+), 5 deletions(-) diff --git a/plugins/video/main.py b/plugins/video/main.py index e3ca526..679058b 100644 --- a/plugins/video/main.py +++ b/plugins/video/main.py @@ -151,7 +151,14 @@ class VideoPlugin(MessagePluginInterface): try: # 发送GET请求,启用流式传输 self.LOG.info(f"开始从 {url} 下载视频") - response = requests.get(url, stream=True, timeout=30) + headers = { + "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36", + "Accept": "*/*", + "Accept-Encoding": "gzip, deflate, br", + "Connection": "keep-alive", + "Referer": "https://api.guiguiya.com/" + } + response = requests.get(url, stream=True, timeout=30, headers=headers, allow_redirects=True) # 检查请求是否成功 response.raise_for_status() # 如果状态码不是200,将抛出异常 @@ -173,18 +180,41 @@ class VideoPlugin(MessagePluginInterface): # 以二进制写入模式保存流数据 try: + total_size = int(response.headers.get('Content-Length', 0)) + self.LOG.info(f"预期下载大小: {total_size} 字节") + downloaded_size = 0 + with open(save_path, "wb") as file: for chunk in response.iter_content(chunk_size=1024): # 分块读取,每块1KB if chunk: # 过滤空块 file.write(chunk) - self.LOG.info(f"视频已下载到: {save_path}") + downloaded_size += len(chunk) + + self.LOG.info(f"视频已下载到: {save_path}, 大小: {downloaded_size} 字节") + + # 验证下载是否完整 + if total_size > 0 and downloaded_size < total_size * 0.9: # 如果下载不到预期大小的90% + self.LOG.error(f"下载不完整: 预期 {total_size} 字节, 实际 {downloaded_size} 字节") + return None, None except IOError as e: self.LOG.error(f"文件写入失败: {e}") return None, None - # 检查文件是否存在且大小大于0 - if not os.path.exists(save_path) or os.path.getsize(save_path) == 0: - self.LOG.error(f"下载的文件不存在或为空: {save_path}") + # 检查文件是否存在且大小合理 + if not os.path.exists(save_path): + self.LOG.error(f"下载的文件不存在: {save_path}") + return None, None + + file_size = os.path.getsize(save_path) + if file_size < 10000: # 小于10KB的文件可能不是有效视频 + self.LOG.error(f"下载的文件太小,可能不是有效视频: {file_size} 字节") + # 尝试读取文件内容以诊断问题 + try: + with open(save_path, 'rb') as f: + content_preview = f.read(200) + self.LOG.warning(f"文件内容预览(十六进制): {content_preview.hex()[:100]}") + except Exception as e: + self.LOG.error(f"读取文件内容失败: {e}") return None, None # 加入首帧下载