From 0c555e195487b4f49bd23d9d6171fc337e2d1156 Mon Sep 17 00:00:00 2001 From: ShilongLee <1261586682@qq.com> Date: Mon, 29 Jul 2024 11:57:25 +0800 Subject: [PATCH] =?UTF-8?q?MOD:=E5=B0=8F=E7=BA=A2=E4=B9=A6=E5=8A=A8?= =?UTF-8?q?=E6=80=81=E8=8E=B7=E5=8F=96xsec=5Ftoken?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- service/xhs/logic/detail.py | 23 +++++++++++++++++++++-- 1 file changed, 21 insertions(+), 2 deletions(-) diff --git a/service/xhs/logic/detail.py b/service/xhs/logic/detail.py index 3a3749a..c3505dc 100644 --- a/service/xhs/logic/detail.py +++ b/service/xhs/logic/detail.py @@ -1,12 +1,31 @@ -from .common import common_request +from .common import common_request, COMMON_HEADERS +from lib import requests +from lib import logger +import re + async def request_detail(id: str, cookie: str) -> tuple[dict, bool]: """ 请求小红书获取视频信息 """ + # 获取xsec_token + url = 'https://www.xiaohongshu.com/explore' + headers = {"cookie": cookie} + headers.update(COMMON_HEADERS) + resp = await requests.get(url, headers=headers) + if resp.status_code != 200 or resp.text == '': + return {}, False + pattern = r'xsec_token=(.*?)&' + match = re.search(pattern, resp.text) + if not match: + logger.error("No xsec_token match found.") + return {}, False + xsec_token = match.group(1) + + # 获取详情 params = {"source_note_id": id, "image_formats": [ - "jpg", "webp", "avif"], "extra": {"need_body_topic": "1"}} + "jpg", "webp", "avif"], "extra": {"need_body_topic": "1"}, "xsec_source": "pc_feed", "xsec_token": xsec_token} headers = {"cookie": cookie} resp, succ = await common_request('/api/sns/web/v1/feed', params, headers) if not succ: