抖音ck提取工具,快手小红书微博哔哩哔哩cookie提取登录软件,python框架

简介: 这个框架提供了完整的Cookie提取功能,支持抖音、快手、小红书、微博和哔哩哔哩平台。主要特点包括

下载地址:https://www.pan38.com/share.php?code=JCnzE 提取密码:1112

这个框架提供了完整的Cookie提取功能,支持抖音、快手、小红书、微博和哔哩哔哩平台。主要特点包括:1) 模块化设计,易于扩展新平台;2) 自动验证Cookie有效性;3) 本地SQLite数据库存储历史记录;4) 支持从浏览器直接提取Cookie。使用时需要安装browser-cookie3和requests库。

import os
import json
import sqlite3
import browser_cookie3
from typing import Dict, Optional
from datetime import datetime
import requests
from urllib.parse import urlparse

class BaseCookieExtractor:
"""基础Cookie提取类"""
def init(self):
self.platform_name = "base"
self.required_cookies = []
self.domain = ""

def extract(self) -> Dict[str, str]:
    """提取Cookies的基类方法"""
    raise NotImplementedError

def validate_cookies(self, cookies: Dict[str, str]) -> bool:
    """验证Cookies是否有效"""
    if not all(k in cookies for k in self.required_cookies):
        return False
    return True

def test_cookies(self, cookies: Dict[str, str]) -> bool:
    """测试Cookies是否有效"""
    raise NotImplementedError
AI 代码解读

class DouyinCookieExtractor(BaseCookieExtractor):
"""抖音Cookie提取器"""
def init(self):
super().init()
self.platform_name = "douyin"
self.required_cookies = ["sessionid", "odin_tt"]
self.domain = ".douyin.com"

def extract(self) -> Dict[str, str]:
    cookies = {}
    try:
        cj = browser_cookie3.load(domain_name=self.domain)
        for cookie in cj:
            if cookie.domain.endswith(self.domain):
                cookies[cookie.name] = cookie.value
    except Exception as e:
        print(f"提取抖音Cookie失败: {e}")
    return cookies

def test_cookies(self, cookies: Dict[str, str]) -> bool:
    if not self.validate_cookies(cookies):
        return False
    try:
        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",
            "Cookie": "; ".join([f"{k}={v}" for k, v in cookies.items()])
        }
        response = requests.get(
            "https://www.douyin.com/aweme/v1/web/aweme/post/",
            headers=headers,
            timeout=10
        )
        return response.status_code == 200
    except Exception:
        return False
AI 代码解读

class KuaishouCookieExtractor(BaseCookieExtractor):
"""快手Cookie提取器"""
def init(self):
super().init()
self.platform_name = "kuaishou"
self.required_cookies = ["did", "kuaishou.server.web_ph"]
self.domain = ".kuaishou.com"

def extract(self) -> Dict[str, str]:
    cookies = {}
    try:
        cj = browser_cookie3.load(domain_name=self.domain)
        for cookie in cj:
            if cookie.domain.endswith(self.domain):
                cookies[cookie.name] = cookie.value
    except Exception as e:
        print(f"提取快手Cookie失败: {e}")
    return cookies

def test_cookies(self, cookies: Dict[str, str]) -> bool:
    if not self.validate_cookies(cookies):
        return False
    try:
        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",
            "Cookie": "; ".join([f"{k}={v}" for k, v in cookies.items()])
        }
        response = requests.get(
            "https://www.kuaishou.com/graphql",
            headers=headers,
            timeout=10
        )
        return response.status_code == 200
    except Exception:
        return False
AI 代码解读

class CookieManager:
"""Cookie管理器"""
def init(self):
self.extractors = {
"douyin": DouyinCookieExtractor(),
"kuaishou": KuaishouCookieExtractor(),
"xiaohongshu": XiaoHongShuCookieExtractor(),
"weibo": WeiboCookieExtractor(),
"bilibili": BilibiliCookieExtractor()
}
self.cookie_db = "cookies.db"
self._init_db()

def _init_db(self):
    """初始化数据库"""
    conn = sqlite3.connect(self.cookie_db)
    cursor = conn.cursor()
    cursor.execute("""
    CREATE TABLE IF NOT EXISTS cookies (
        platform TEXT,
        cookies TEXT,
        timestamp DATETIME,
        valid INTEGER,
        PRIMARY KEY (platform, timestamp)
    )
    """)
    conn.commit()
    conn.close()

def extract_all(self):
    """提取所有平台的Cookies"""
    results = {}
    for platform, extractor in self.extractors.items():
        cookies = extractor.extract()
        is_valid = extractor.test_cookies(cookies)
        results[platform] = {
            "cookies": cookies,
            "valid": is_valid
        }
        self._save_cookies(platform, cookies, is_valid)
    return results

def _save_cookies(self, platform: str, cookies: Dict[str, str], valid: bool):
    """保存Cookies到数据库"""
    conn = sqlite3.connect(self.cookie_db)
    cursor = conn.cursor()
    cursor.execute("""
    INSERT INTO cookies (platform, cookies, timestamp, valid)
    VALUES (?, ?, ?, ?)
    """, (
        platform,
        json.dumps(cookies),
        datetime.now().isoformat(),
        int(valid)
    ))
    conn.commit()
    conn.close()

def get_latest_valid_cookies(self, platform: str) -> Optional[Dict[str, str]]:
    """获取最新有效的Cookies"""
    conn = sqlite3.connect(self.cookie_db)
    cursor = conn.cursor()
    cursor.execute("""
    SELECT cookies FROM cookies
    WHERE platform = ? AND valid = 1
    ORDER BY timestamp DESC
    LIMIT 1
    """, (platform,))
    row = cursor.fetchone()
    conn.close()
    if row:
        return json.loads(row[0])
    return None
AI 代码解读

if name == "main":
manager = CookieManager()
all_cookies = manager.extract_all()
print("提取结果:")
for platform, data in all_cookies.items():
print(f"{platform}: {'有效' if data['valid'] else '无效'}")
print(f"Cookies: {json.dumps(data['cookies'], indent=2)}")

XiaoHongShuCookieExtractor(BaseCookieExtractor):
"""小红书Cookie提取器"""
def init(self):
super().init()
self.platform_name = "xiaohongshu"
self.required_cookies = ["a1", "web_session"]
self.domain = ".xiaohongshu.com"

def extract(self) -> Dict[str, str]:
    cookies = {}
    try:
        cj = browser_cookie3.load(domain_name=self.domain)
        for cookie in cj:
            if cookie.domain.endswith(self.domain):
                cookies[cookie.name] = cookie.value
    except Exception as e:
        print(f"提取小红书Cookie失败: {e}")
    return cookies

def test_cookies(self, cookies: Dict[str, str]) -> bool:
    if not self.validate_cookies(cookies):
        return False
    try:
        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",
            "Cookie": "; ".join([f"{k}={v}" for k, v in cookies.items()])
        }
        response = requests.get(
            "https://www.xiaohongshu.com/fe_api/burdock/v2/homefeed",
            headers=headers,
            timeout=10
        )
        return response.status_code == 200
    except Exception:
        return False
AI 代码解读

class WeiboCookieExtractor(BaseCookieExtractor):
"""微博Cookie提取器"""
def init(self):
super().init()
self.platform_name = "weibo"
self.required_cookies = ["SUB", "XSRF-TOKEN"]
self.domain = ".weibo.com"

def extract(self) -> Dict[str, str]:
    cookies = {}
    try:
        cj = browser_cookie3.load(domain_name=self.domain)
        for cookie in cj:
            if cookie.domain.endswith(self.domain):
                cookies[cookie.name] = cookie.value
    except Exception as e:
        print(f"提取微博Cookie失败: {e}")
    return cookies

def test_cookies(self, cookies: Dict[str, str]) -> bool:
    if not self.validate_cookies(cookies):
        return False
    try:
        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",
            "Cookie": "; ".join([f"{k}={v}" for k, v in cookies.items()])
        }
        response = requests.get(
            "https://weibo.com/ajax/feed/hottimeline",
            headers=headers,
            timeout=10
        )
        return response.status_code == 200
    except Exception:
        return False
AI 代码解读

class BilibiliCookieExtractor(BaseCookieExtractor):
"""哔哩哔哩Cookie提取器"""
def init(self):
super().init()
self.platform_name = "bilibili"
self.required_cookies = ["SESSDATA", "bili_jct"]
self.domain = ".bilibili.com"

def extract(self) -> Dict[str, str]:
    cookies = {}
    try:
        cj = browser_cookie3.load(domain_name=self.domain)
        for cookie in cj:
            if cookie.domain.endswith(self.domain):
                cookies[cookie.name] = cookie.value
    except Exception as e:
        print(f"提取哔哩哔哩Cookie失败: {e}")
    return cookies

def test_cookies(self, cookies: Dict[str, str]) -> bool:
    if not self.validate_cookies(cookies):
        return False
    try:
        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",
            "Cookie": "; ".join([f"{k}={v}" for k, v in cookies.items()])
        }
        response = requests.get(
            "https://api.bilibili.com/x/web-interface/nav",
            headers=headers,
            timeout=10
        )
        return response.status_code == 200 and response.json().get("data", {}).get("isLogin", False)
    except Exception:
        return False
AI 代码解读
目录
打赏
0
3
3
0
18
分享
相关文章
拼多多批量上架软件, 电商一键上货发布工具,python电商框架分享
多线程批量上传架构,支持并发处理商品数据 完整的拼多多API签名和token管理机制
淘宝批量上架软件脚本,电商一键上货软件, 淘宝一键铺货软件【python】
核心功能:实现淘宝商品批量上传,包含登录认证、商品数据处理、图片处理和API调用 多线程处理
一键修改电脑机器码, 软件机器码一键修改工具, 机器码重置工具【python】
该工具实现了完整的机器码生成、加密、验证功能 使用系统硬件信息生成唯一机器码
微信自动抢红包永久免费软件, 自动抢红包软件微信,脚本插件抢红包【python】
该实现包含三个核心模块:主监控程序、数据库记录模块和配置模块。主程序使用itchat监听微信消息
Python 高级编程与实战:深入理解性能优化与调试技巧
本文深入探讨了Python的性能优化与调试技巧,涵盖profiling、caching、Cython等优化工具,以及pdb、logging、assert等调试方法。通过实战项目,如优化斐波那契数列计算和调试Web应用,帮助读者掌握这些技术,提升编程效率。附有进一步学习资源,助力读者深入学习。
|
2月前
|
Python编程基石:整型、浮点、字符串与布尔值完全解读
本文介绍了Python中的四种基本数据类型:整型(int)、浮点型(float)、字符串(str)和布尔型(bool)。整型表示无大小限制的整数,支持各类运算;浮点型遵循IEEE 754标准,需注意精度问题;字符串是不可变序列,支持多种操作与方法;布尔型仅有True和False两个值,可与其他类型转换。掌握这些类型及其转换规则是Python编程的基础。
182 33
不会Python,还敢说搞大数据?一文带你入门大数据编程的“硬核”真相
不会Python,还敢说搞大数据?一文带你入门大数据编程的“硬核”真相
67 1

热门文章

最新文章

下一篇
对象存储OSS
AI助理
登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问

你好,我是AI助理

可以解答问题、推荐解决方案等