diff --git a/config/config.ini b/config/config.ini new file mode 100644 index 0000000..380f339 --- /dev/null +++ b/config/config.ini @@ -0,0 +1,3 @@ +[test] +DASHSCOPE_API_KEY=sk-063b48fffb914d558ddcddc5166fd34d +[pro] diff --git a/main.py b/main.py index 41690cf..9173126 100644 --- a/main.py +++ b/main.py @@ -1,122 +1,67 @@ -from fastapi import FastAPI, Query -import uvicorn +#!/usr/bin/env python +# -*- coding: utf-8 -*- +from fastapi import FastAPI, Request +from fastapi.responses import FileResponse +import uvicorn, os +from utils.music_analysis import music_analysis, chat_analysis import requests -from utils.response import success_response, error_400_response, error_503_response -from utils.music_analysis import music_analysis -import os +from utils.response import success_response, error_response app = FastAPI(title="douyin文档", swagger_ui_parameters={ "defaultModelsExpandDepth": -1 }) -DEFAULT_PC_VIDEO_URL = 'https://v.douyin.com/-NvlqBdIJo4/' -DEFAULT_mobile_VIDEO_URL = 'https://v.douyin.com/BCfMrTFPYGQ/' ENVIRONMENT = os.getenv("ENVIRONMENT", "test") -host = '127.0.0.1:9579' +host = 'http://127.0.0.1:9579' if ENVIRONMENT == "pro": host = 'http://douyin_tiktok_download_api:80' -@app.get('/douyin_video', tags=["抖音"], summary="返回视屏信息,最全的接口了") -def douyin_video(video_url: str = Query(DEFAULT_mobile_VIDEO_URL, min_length=10)): - print(video_url) +@app.post('/douyin', tags=["抖音"], summary="分享链接获取抖音详细信息") +async def douyin(request: Request): + os.environ["DASHSCOPE_API_KEY"] = "sk-063b48fffb914d558ddcddc5166fd34d" + form_data = await request.form() + video_url = form_data.get('video_url', '').strip() + print(f'原始视频url为:{video_url}') if not video_url: - return {"code": 400, "message": "An error occurred.", "data": "请指定video_url"} + return error_response(400, data='video_url 参数缺失') + elif len(video_url) < 21: + return error_response(400, data='video_url 参数长度不够') + video_url = chat_analysis(video_url) + print(f'截取后视频url为:{video_url}') + if not video_url: + return error_response(400, data='解析不到url') + elif len(video_url) < 21: + return error_response(400, data='解析到的url长度不够') - # 获取get请求参数 + # 获取get请求参数 url = host + "/api/hybrid/video_data" + print(url) querystring = {"url": video_url, "minimal": "true"} response = requests.request("GET", url, params=querystring) print(response.text) - print(response.json()['data']['music']['play_url']) try: if response.json()['code'] == 200: video_url = response.json()['data']['video_data']['wm_video_url'] video_music = response.json()['data']['music']['play_url']['url_list'][0] content = music_analysis(video_music) - return success_response({"video_url": video_url, "video_music": video_music, "content": content - }) - + return success_response(200, data={"video_url": video_url, "video_music": video_music, "content": content + }) except Exception as e: print(e) - return error_400_response({"data": "解析字段失败."}) + return error_response(400, data='解析字段失败') - return error_503_response({"data": "抖音风控稍后请求."}) + return error_response(500, data='其他异常') -@app.get('/douyin_content', tags=["抖音"], summary="手机和pc获取文案") -def douyin_content(video_url: str = Query(DEFAULT_mobile_VIDEO_URL, min_length=10)): - print(video_url) - if not video_url: - return {"code": 400, "message": "An error occurred.", "data": "请指定video_url"} - - # 获取get请求参数 - url = host + "/api/hybrid/video_data" - - querystring = {"url": video_url, "minimal": "false"} - response = requests.request("GET", url, params=querystring) - print(response.text) +@app.get('/') +def index(): try: - if response.json()['code'] == 200: - return success_response({"content": response.json()['data']['seo_info']['ocr_content'], - }) - - except Exception as e: - print(e) - return error_400_response({"data": "解析字段失败."}) - - return error_503_response({"data": "抖音风控稍后请求."}) - - -@app.get('/douyin_pc', tags=["抖音"], summary="返回pc文案和视频") -def douyin_pc(video_url: str = Query(DEFAULT_PC_VIDEO_URL, min_length=10)): - print(video_url) - if not video_url: - return {"code": 400, "message": "An error occurred.", "data": "请指定video_url"} - - # 获取get请求参数 - url = host + "/api/hybrid/video_data" - - querystring = {"url": video_url, "minimal": "false"} - response = requests.request("GET", url, params=querystring) - print(response.text) - try: - if response.json()['code'] == 200: - return success_response({"content": response.json()['data']['seo_info']['ocr_content'], - "pc_url": response.json()['data']['video']['bit_rate'][0]['play_addr']['url_list'] - }) - - except Exception as e: - print(e) - return error_400_response({"data": "解析字段失败."}) - - return error_503_response({"data": "抖音风控稍后请求."}) - - -@app.get('/douyin_phone', tags=["抖音"], summary="返回手机视屏地址") -def douyin_phone(video_url: str = Query(DEFAULT_mobile_VIDEO_URL, min_length=10)): - print(video_url) - if not video_url: - return {"code": 400, "message": "An error occurred.", "data": "请指定video_url"} - - # 获取get请求参数 - url = host + "/api/hybrid/video_data" - - querystring = {"url": video_url, "minimal": "true"} - response = requests.request("GET", url, params=querystring) - print(response.text) - try: - if response.json()['code'] == 200: - return success_response({"phone_url": response.json()['data']['video_data']['wm_video_url'] - }) - - except Exception as e: - print(e) - return error_400_response({"data": "解析字段失败."}) - - return error_503_response({"data": "抖音风控稍后请求."}) + return FileResponse('templates/index.html') + except FileNotFoundError: + return {'error': 'index.html 文件未找到'}, 404 if __name__ == '__main__': diff --git a/requirements.txt b/requirements.txt index f1253e6..3b033c5 100644 Binary files a/requirements.txt and b/requirements.txt differ diff --git a/templates/index.html b/templates/index.html new file mode 100644 index 0000000..1a8211d --- /dev/null +++ b/templates/index.html @@ -0,0 +1,133 @@ + + +
+ +