当前位置:首页>python>Python自动化实战:打造抖音多端口粉丝管理工具

Python自动化实战:打造抖音多端口粉丝管理工具

  • 2026-06-24 15:23:12
Python自动化实战:打造抖音多端口粉丝管理工具

Python自动化实战:打造抖音多端口粉丝管理工具,从CLI到GUI的完整演进

原创不易,文末获取完整源码!本文将带你从零打造一个功能强大的抖音粉丝自动化管理工具,涵盖CLI命令行和GUI图形界面两种模式,支持多端口并发运行,SQLite数据库持久化,以及完整的日志追踪系统。

📌 写在前面

在日常的抖音运营工作中,我们经常需要批量关注对标账号的粉丝,这是快速增长粉丝的有效手段之一。但手动操作存在以下痛点:

  • 效率低下
    :逐个点击关注,耗时耗力
  • 易被检测
    :机械重复操作容易被平台识别
  • 管理困难
    :无法记录关注状态,容易重复操作
  • 单账号限制
    :无法同时管理多个账号

基于这些痛点,我开发了这款抖音定制粉丝运营工具,完美解决了上述问题。

🎯 项目核心特性

$3

  • CLI模式
    :轻量级命令行版本,适合批处理和自动化脚本
  • GUI模式
    :可视化图形界面,实时监控操作进度和日志

$3

# 支持100+个Chrome实例同时运行ports = [9222, 9223, 9224, ...]# 每个端口独立管理一个抖音账号

$3

-- SQLite数据库记录所有操作CREATE TABLE fans (    id INTEGER PRIMARY KEY,    my_account_name TEXT,    port INTEGER,    target_account_id TEXT,    fan_user_id TEXT,    state INTEGER,  -- 0:未关注 1:已关注 -1:已取消    created_at TIMESTAMP);

$3

# 随机延迟降低检测风险sleep_time = parse_sleep_time("2-5")  # 2到5秒随机time.sleep(sleep_time)

🛠 技术栈选型

技术
用途
选择理由
DrissionPage
浏览器自动化
比Selenium更稳定,支持已打开浏览器连接
tkinter
GUI界面
Python内置,无需额外依赖,轻量高效
SQLite
数据存储
轻量级数据库,无需配置服务器,适合单机应用
loguru
日志管理
比标准库logging更强大,自动轮转和格式化
threading
并发控制
每个端口独立线程,互不干扰

🏗 项目架构设计

$3

┌─────────────────────────────────────────────────┐│           抖音粉丝运营工具                       │├─────────────────────────────────────────────────┤│                                                 ││  ┌──────────────┐      ┌──────────────┐       ││  │  CLI版本     │      │  GUI版本     │       ││  │  (app.py)    │      │  (gui/)      │       ││  └──────────────┘      └──────────────┘       ││                               │                 ││                    ┌─────────┴─────────┐       ││                    │                   │       ││            ┌───────▼──────┐   ┌───────▼───────┐││            │ PortManager  │   │  MainWindow   │││            │  端口管理器   │   │   主窗口      │││            └──────────────┘   └───────────────┘││                    │                   │        ││            ┌───────┴───────────────────▼───────┐││            │        WorkerThread (后台线程)     │││            │  - FollowWorker  关注任务          │││            │  - CancelWorker 取消任务           │││            └───────────────────────────────────┘││                    │                            ││    ┌───────────────┼───────────────┐           ││    │               │               │           ││ ▼───▼          ▼───▼          ▼───▼            ││Browser      Database      LogSystem            ││浏览器      数据库        日志系统              │└─────────────────────────────────────────────────┘

$3

1. Browser模块(浏览器管理)

# gui/browser.pyclass BrowserManager:    """浏览器连接管理"""    def connect(self, port: int):        """连接到指定端口的Chrome浏览器"""        browser = Chromium(addr_or_opts=f'127.0.0.1:{port}')        return browser.latest_tab

关键技术点

  • 使用Chrome的远程调试模式
  • 支持连接到已打开的浏览器实例
  • 每个端口独立的用户数据目录

2. Database模块(数据管理)

# gui/database.pydef init_db(db_path=None):    """初始化数据库"""    if db_path is None:        # 开发环境:数据库在gui目录下        current_dir = os.path.dirname(os.path.abspath(__file__))        db_path = os.path.join(current_dir, 'douyin_fans.db')    conn = sqlite3.connect(db_path, check_same_thread=False)    # 创建表结构...    return conn

数据表设计

-- 粉丝关注状态表CREATE TABLE fans (    id INTEGER PRIMARY KEY AUTOINCREMENT,    my_account_name TEXT NOT NULL,    port INTEGER NOT NULL,    target_account_id TEXT NOT NULL,    fan_user_id TEXT NOT NULL,    fan_home_link TEXT,    nickname TEXT,    state INTEGER DEFAULT 0,  -- 0:未关注 1:已关注 -1:已取消    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,    updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,    UNIQUE(my_account_name, port, target_account_id, fan_user_id));-- 操作日志表CREATE TABLE operation_log (    id INTEGER PRIMARY KEY AUTOINCREMENT,    my_account_name TEXT NOT NULL,    port INTEGER NOT NULL,    operation_type TEXT NOT NULL,  -- follow/unfollow    target_account_id TEXT NOT NULL,    fan_user_id TEXT,    nickname TEXT,    action TEXT NOT NULL,    result TEXT,    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP);

3. Worker模块(任务执行)

# gui/worker.pyclass FollowWorker(threading.Thread):    """关注任务工作线程"""    def run(self):        """执行关注任务"""        for target in self.target_links:            # 1. 打开对标账号粉丝列表            self.page.get(link)            # 2. 检查粉丝列表是否公开            if self._is_fans_list_public():                # 3. 处理粉丝列表                self._process_fans_list(target_account_id, start_time)    def _process_fans_list(self, target_account_id, start_time):        """处理粉丝列表 - 核心逻辑"""        fan_container = self.page.ele('@class=FjupSA6k', timeout=10)        processed_index = 0        while True:            # 获取当前可见的粉丝项            fan_items = fan_container.eles('@class=i5U4dMnB')            total_items = len(fan_items)            if total_items <= processed_index:                break  # 没有更多粉丝            # 处理新加载的粉丝            for index in range(processed_index, total_items):                fan_item = fan_items[index]                # 获取粉丝信息                nickname = fan_item.ele('t:span@@class=arnSiSbK').text                fan_main_link = fan_item.ele('t:a@@class=uz1VJwFY').link                btn_ele = fan_item.ele('@class=HrvFYsXO qiKy46zD').ele('t:button')                button_text = btn_ele.text                # 判断关注状态                if button_text == '关注':                    # 执行关注操作                    btn_ele.click('js')                    time.sleep(sleep_time)                    # 更新数据库状态...            # 滚动加载更多            processed_index = total_items            fan_container.scroll.to_bottom()            time.sleep(2)

关键技术点

  • 独立线程执行,避免阻塞GUI
  • 滚动加载机制,确保处理所有粉丝
  • 实时更新数据库和日志

💡 核心功能实现

$3

# gui/port_manager.pyclass PortManager:    """管理多个浏览器端口"""    def __init__(self):        self.ports = {}  # {port: PortInfo}        self.workers = {}  # {port: WorkerThread}    def add_port(self, port, account_file, sleep_time, run_time):        """添加新端口"""        port_info = PortInfo(            port=port,            account_file=account_file,            sleep_time=sleep_time,            run_time=run_time        )        self.ports[port] = port_info        return port_info    def start_follow_task(self, port, page, user_name, target_links):        """启动关注任务"""        worker = FollowWorker(            port=port,            page=page,            user_name=user_name,            target_links=target_links,            sleep_time=self.ports[port].sleep_time,            run_time=self.ports[port].run_time        )        self.workers[port] = worker        worker.start()

$3

def _search_user_by_id(self, user_id: str) -> str:    """根据用户ID搜索获取主页链接"""    try:        # 1. 打开搜索页面        self.page.get('https://www.douyin.com/jingxuan')        # 2. 输入用户ID        self.page.ele('t:input@@class=YEhxqQNi jUqDCyab').input(user_id)        # 3. 点击搜索按钮        self.page.ele('@class=YQK6ciuU Gs5TnHUH', timeout=3).click()        # 4. 等待搜索结果        time.sleep(3)        # 5. 获取第一个搜索结果链接        main_link = self.page.ele('@class=search-result-card', timeout=10).ele('t:a').link        return main_link    except Exception as e:        self.log(f"搜索失败: {e}", 'error')        return None

$3

# gui/sleep_utils.pydef parse_sleep_time(sleep_str: str) -> float:    """    解析睡眠时间配置    支持两种格式:    - 固定值: "3" -> 3秒    - 随机范围: "2-5" -> 2到5秒之间随机    """    if '-' in sleep_str:        # 随机范围: "2-5"        min_val, max_val = map(float, sleep_str.split('-'))        return random.uniform(min_val, max_val)    else:        # 固定值        return float(sleep_str)

$3

# gui/log_panel.pyclass LogPanel:    """日志面板组件"""    def append_log(self, message: str, level: str = 'info'):        """添加日志(线程安全)"""        # 使用after方法确保在主线程更新GUI        self.text_widget.after(0, self._update_log, message, level)    def _update_log(self, message: str, level: str):        """实际更新日志"""        timestamp = datetime.now().strftime('%Y-%m-%d %H:%M:%S')        color = self._get_color_by_level(level)        self.text_widget.insert('end', f"[{timestamp}] {message}\n", color)        self.text_widget.see('end')  # 自动滚动到底部

📦 部署和使用指南

$3

1. 安装依赖

pip install DrissionPage loguru

2. 启动Chrome浏览器(远程调试模式)

创建批处理文件 start_chrome.bat

@echo offecho 启动Chrome浏览器(端口9222-9225)start "" "C:\Program Files\Google\Chrome\Application\chrome.exe" --remote-debugging-port=9222 --user-data-dir="C:\chrome_profile_9222"start "" "C:\Program Files\Google\Chrome\Application\chrome.exe" --remote-debugging-port=9223 --user-data-dir="C:\chrome_profile_9223"start "" "C:\Program Files\Google\Chrome\Application\chrome.exe" --remote-debugging-port=9224 --user-data-dir="C:\chrome_profile_9224"start "" "C:\Program Files\Google\Chrome\Application\chrome.exe" --remote-debugging-port=9225 --user-data-dir="C:\chrome_profile_9225"echo 浏览器启动完成!pause

3. 准备账号文件

创建 accounts.txt

https://www.douyin.com/user/MS4wLjABAAAA9s0yrAQhOh6o3lHJ1cdo8dUu901Pjw1LHGLvprmDFuMhttps://www.douyin.com/user/ANOTHER_USER_IDMS4wLjABAAAA_YET_ANOTHER_USER_ID

$3

GUI模式

python gui/gui_main.py

CLI模式

python app.py

$3

pip install pyinstallerpyinstaller --onefile --name="抖音粉丝工具" gui/gui_main.py

打包后的文件在 dist/ 目录。

🎨 界面展示

$3

┌─────────────────────────────────────────────────────────────┐│  抖音批量关注工具 - 多端口管理版                              │├─────────────────────────────────────────────────────────────┤│  [添加端口] [数据库查看] [全局设置] [停止全部]                │├─────────────────────────────────────────────────────────────┤│ ┌─────┬─────┬─────┬─────┐  ┌─────────────────────────────┐ ││ │端口1 │端口2 │端口3 │端口4 │  │      数据表格区域          │ ││ │(Tab) │(Tab) │(Tab) │(Tab) │  │  (粉丝状态/操作日志)       │ ││ └─────┴─────┴─────┴─────┘  │                             │ ││                          │  ┌─────────────────────────┐  │ ││  当前端口配置区域         │  │  Table显示数据           │  │ ││  ┌─────────────────────┐ │  │  - 可筛选/排序          │  │ ││  │ 端口: 9222          │ │  │  - 支持分页             │  │ ││  │ 账号文件: [选择]    │ │  └─────────────────────────┘  │ ││  │ 间隔时间: [3]秒     │ │                             │ ││  │ 运行时长: [3600]秒  │ │                             │ ││  │ [登录] [开始关注]   │ │                             │ ││  │ [开始取消] [停止]   │ │                             │ ││  └─────────────────────┘ │                             │ │├──────────────────────────┴─────────────────────────────┤ ││  ┌─────────────────────────────────────────────────────┐ ││  │              日志区域 (实时滚动)                      │ ││  │  [2025-01-07 10:30:15] 端口9222: 开始关注...        │ ││  │  [2025-01-07 10:30:16] 端口9222: 关注成功 张三      │ ││  └─────────────────────────────────────────────────────┘ │└─────────────────────────────────────────────────────────────┘

🔧 技术难点与解决方案

$3

问题:Python的tkinter不是线程安全的,子线程无法直接更新GUI。

解决方案:使用 after() 方法在主线程中执行GUI更新。

# 错误做法:子线程直接更新GUIlabel.config(text="xxx")  # ❌ 会崩溃# 正确做法:使用after回调root.after(0, lambda: label.config(text="xxx"))  # ✅ 线程安全

$3

问题:多个线程同时访问SQLite数据库可能发生锁冲突。

解决方案:使用单例模式 + 线程锁。

import threading_db_conn = None_db_lock = threading.Lock()def get_db():    """获取数据库连接(单例模式)"""    global _db_conn    if _db_conn is None:        _db_conn = init_db()    return _db_conndef update_fan_state(...):    """更新粉丝状态(线程安全)"""    with _db_lock:  # 加锁        cursor = get_db().cursor()        cursor.execute(...)        get_db().commit()

$3

问题:相对路径在不同运行环境下解析不一致,导致数据不同步。

解决方案:使用绝对路径,区分开发和打包环境。

def init_db(db_path=None):    if db_path is None:        import sys        if getattr(sys, 'frozen', False):            # 打包后的exe:数据库在exe同目录            db_path = os.path.join(os.path.dirname(sys.executable), 'douyin_fans.db')        else:            # 开发环境:数据库在gui目录下            current_dir = os.path.dirname(os.path.abspath(__file__))            db_path = os.path.join(current_dir, 'douyin_fans.db')    conn = sqlite3.connect(db_path, check_same_thread=False)    return conn

$3

问题:抖音页面元素经常更新,class名称不固定。

解决方案:使用多重定位策略。

# 策略1:使用模糊匹配fans_element = page.ele('@class=cuA7Ana_').ele('t:div@@text():粉丝', timeout=3)# 策略2:使用多属性定位button = fan_item.ele('@class=HrvFYsXO qiKy46zD').ele('t:button')# 策略3:异常捕获try:    nickname = fan_item.ele('t:span@@class=arnSiSbK').textexcept:    log.warning("获取昵称失败,跳过")    continue

📊 性能优化

$3

-- 创建索引加快查询速度CREATE INDEX idx_fans_lookup ON fans(my_account_name, port, target_account_id, fan_user_id);CREATE INDEX idx_fans_state ON fans(state);CREATE INDEX idx_op_log_port ON operation_log(port);CREATE INDEX idx_op_log_type ON operation_log(operation_type);

$3

# 不推荐:逐条插入for fan in fans:    cursor.execute("INSERT INTO fans ...", fan_data)    conn.commit()  # ❌ 每次都提交,性能差# 推荐:批量插入for fan in fans:    cursor.execute("INSERT INTO fans ...", fan_data)conn.commit()  # ✅ 一次性提交

$3

# 固定延迟(容易被检测)time.sleep(3)  # ❌# 随机延迟(模拟真人)sleep_time = random.uniform(2, 5)  # ✅time.sleep(sleep_time)

🚀 项目亮点

  1. 双模式支持
    :CLI + GUI,满足不同场景需求
  2. 多端口并发
    :支持100+账号同时运营
  3. 数据持久化
    :SQLite完整记录所有操作
  4. 智能重试
    :异常自动处理,任务不中断
  5. 配置化
    :JSON配置文件,灵活管理
  6. 日志追踪
    :完整的操作日志,方便审计
  7. 真人模拟
    :随机延迟,降低检测风险
  8. 数据库查看
    :内置数据查看器,无需外部工具

📈 未来规划

  •  分批轮换功能(每批运行指定数量端口)
  •  关注数量上限设置(每个对标账号关注N个后切换)
  •  次日自动启动(定时任务调度)
  •  更多随机行为(随机暂停、随机跳过)
  •  Web管理界面(远程监控)
  •  Docker容器化部署

🎓 学习收获

通过这个项目,你可以学到:

  1. DrissionPage实战
    :浏览器自动化的最佳实践
  2. GUI开发
    :tkinter界面设计和事件处理
  3. 多线程编程
    :线程安全和并发控制
  4. 数据库设计
    :SQLite数据建模和优化
  5. 工程化思维
    :模块化设计、配置管理、日志系统
  6. 打包发布
    :PyInstaller打包Python项目

📁 完整源码

私信获取或定制开发

$3

douyin_fans_tool/├── app.py                    # CLI版本├── README.md                 # 项目文档├── gui/                      # GUI版本│   ├── gui_main.py          # 主程序入口│   ├── main_window.py       # 主窗口│   ├── port_manager.py      # 端口管理│   ├── browser.py           # 浏览器管理│   ├── worker.py            # 后台任务│   ├── database.py          # 数据库操作│   ├── db_viewer.py         # 数据库查看│   └── ...└── 博客文章.md              # 本文件

💬 总结

这个项目从实际运营需求出发,结合自动化技术和软件工程最佳实践,打造了一个功能完善、易于使用的抖音粉丝管理工具。

技术特点

  • 稳定性:多线程 + 异常处理,任务不中断
  • 可扩展性:模块化设计,易于添加新功能
  • 用户友好:GUI界面,实时反馈
  • 数据驱动:完整的数据记录和查看

适用场景

  • 抖音个人号批量运营
  • 矩阵账号管理
  • 粉丝增长策略研究
  • 自动化学习参考

希望这个项目对你有所帮助!如果有问题或建议,欢迎留言讨论。


关于作者专注Python自动化开发,擅长Web自动化、数据处理和工具开发。如有合作需求,欢迎联系!

版权声明本文为原创文章,转载请注明出处。本项目仅供学习交流使用,请勿用于商业用途或违反平台规则的行为。


👇点赞 + 收藏 + 关注,第一时间获取更多Python实战教程!

#Python #自动化 #抖音 #DrissionPage #Tkinter #SQLite #编程开发 #技术分享

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-04 05:19:11 HTTP/2.0 GET : https://f.mffb.com.cn/a/491929.html
  2. 运行时间 : 0.088691s [ 吞吐率:11.28req/s ] 内存消耗:4,423.57kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=e26f8bbaec18c8500a564636f3e6e9f6
  1. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/public/index.php ( 0.79 KB )
  2. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/autoload.php ( 0.17 KB )
  3. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_real.php ( 2.49 KB )
  4. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/platform_check.php ( 0.90 KB )
  5. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/ClassLoader.php ( 14.03 KB )
  6. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/composer/autoload_static.php ( 4.90 KB )
  7. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper.php ( 8.34 KB )
  8. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/helper.php ( 2.19 KB )
  9. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/helper.php ( 1.47 KB )
  10. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/stubs/load_stubs.php ( 0.16 KB )
  11. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Exception.php ( 1.69 KB )
  12. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Facade.php ( 2.71 KB )
  13. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/deprecation-contracts/function.php ( 0.99 KB )
  14. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap.php ( 8.26 KB )
  15. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/polyfill-mbstring/bootstrap80.php ( 9.78 KB )
  16. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/Resources/functions/dump.php ( 1.49 KB )
  17. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-dumper/src/helper.php ( 0.18 KB )
  18. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/symfony/var-dumper/VarDumper.php ( 4.30 KB )
  19. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/App.php ( 15.30 KB )
  20. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-container/src/Container.php ( 15.76 KB )
  21. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/container/src/ContainerInterface.php ( 1.02 KB )
  22. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/provider.php ( 0.19 KB )
  23. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Http.php ( 6.04 KB )
  24. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Str.php ( 7.29 KB )
  25. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Env.php ( 4.68 KB )
  26. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/common.php ( 0.03 KB )
  27. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/helper.php ( 18.78 KB )
  28. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Config.php ( 5.54 KB )
  29. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/app.php ( 0.95 KB )
  30. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cache.php ( 0.78 KB )
  31. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/console.php ( 0.23 KB )
  32. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/cookie.php ( 0.56 KB )
  33. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/database.php ( 2.48 KB )
  34. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Env.php ( 1.67 KB )
  35. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/filesystem.php ( 0.61 KB )
  36. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/lang.php ( 0.91 KB )
  37. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/log.php ( 1.35 KB )
  38. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/middleware.php ( 0.19 KB )
  39. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/route.php ( 1.89 KB )
  40. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/session.php ( 0.57 KB )
  41. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/trace.php ( 0.34 KB )
  42. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/config/view.php ( 0.82 KB )
  43. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/event.php ( 0.25 KB )
  44. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Event.php ( 7.67 KB )
  45. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/service.php ( 0.13 KB )
  46. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/AppService.php ( 0.26 KB )
  47. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Service.php ( 1.64 KB )
  48. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Lang.php ( 7.35 KB )
  49. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/lang/zh-cn.php ( 13.70 KB )
  50. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/Error.php ( 3.31 KB )
  51. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/RegisterService.php ( 1.33 KB )
  52. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/services.php ( 0.14 KB )
  53. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/PaginatorService.php ( 1.52 KB )
  54. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ValidateService.php ( 0.99 KB )
  55. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/service/ModelService.php ( 2.04 KB )
  56. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Service.php ( 0.77 KB )
  57. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Middleware.php ( 6.72 KB )
  58. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/initializer/BootService.php ( 0.77 KB )
  59. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Paginator.php ( 11.86 KB )
  60. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-validate/src/Validate.php ( 63.20 KB )
  61. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/Model.php ( 23.55 KB )
  62. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Attribute.php ( 21.05 KB )
  63. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/AutoWriteData.php ( 4.21 KB )
  64. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/Conversion.php ( 6.44 KB )
  65. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/DbConnect.php ( 5.16 KB )
  66. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/ModelEvent.php ( 2.33 KB )
  67. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/concern/RelationShip.php ( 28.29 KB )
  68. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Arrayable.php ( 0.09 KB )
  69. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/contract/Jsonable.php ( 0.13 KB )
  70. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/model/contract/Modelable.php ( 0.09 KB )
  71. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Db.php ( 2.88 KB )
  72. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/DbManager.php ( 8.52 KB )
  73. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Log.php ( 6.28 KB )
  74. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Manager.php ( 3.92 KB )
  75. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerTrait.php ( 2.69 KB )
  76. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/log/src/LoggerInterface.php ( 2.71 KB )
  77. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cache.php ( 4.92 KB )
  78. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/psr/simple-cache/src/CacheInterface.php ( 4.71 KB )
  79. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/helper/Arr.php ( 16.63 KB )
  80. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/driver/File.php ( 7.84 KB )
  81. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/cache/Driver.php ( 9.03 KB )
  82. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/CacheHandlerInterface.php ( 1.99 KB )
  83. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/Request.php ( 0.09 KB )
  84. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Request.php ( 55.78 KB )
  85. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/middleware.php ( 0.25 KB )
  86. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Pipeline.php ( 2.61 KB )
  87. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/TraceDebug.php ( 3.40 KB )
  88. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/middleware/SessionInit.php ( 1.94 KB )
  89. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Session.php ( 1.80 KB )
  90. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/driver/File.php ( 6.27 KB )
  91. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/SessionHandlerInterface.php ( 0.87 KB )
  92. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/session/Store.php ( 7.12 KB )
  93. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Route.php ( 23.73 KB )
  94. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleName.php ( 5.75 KB )
  95. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Domain.php ( 2.53 KB )
  96. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleGroup.php ( 22.43 KB )
  97. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Rule.php ( 26.95 KB )
  98. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/RuleItem.php ( 9.78 KB )
  99. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/route/app.php ( 1.72 KB )
  100. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/Route.php ( 4.70 KB )
  101. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/dispatch/Controller.php ( 4.74 KB )
  102. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/route/Dispatch.php ( 10.44 KB )
  103. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/controller/Index.php ( 4.81 KB )
  104. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/app/BaseController.php ( 2.05 KB )
  105. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/facade/Db.php ( 0.93 KB )
  106. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/connector/Mysql.php ( 5.44 KB )
  107. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/PDOConnection.php ( 52.47 KB )
  108. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Connection.php ( 8.39 KB )
  109. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/ConnectionInterface.php ( 4.57 KB )
  110. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/builder/Mysql.php ( 16.58 KB )
  111. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Builder.php ( 24.06 KB )
  112. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseBuilder.php ( 27.50 KB )
  113. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/Query.php ( 15.71 KB )
  114. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/BaseQuery.php ( 45.13 KB )
  115. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TimeFieldQuery.php ( 7.43 KB )
  116. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/AggregateQuery.php ( 3.26 KB )
  117. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ModelRelationQuery.php ( 20.07 KB )
  118. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ParamsBind.php ( 3.66 KB )
  119. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/ResultOperation.php ( 7.01 KB )
  120. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/WhereQuery.php ( 19.37 KB )
  121. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/JoinAndViewQuery.php ( 7.11 KB )
  122. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/TableFieldInfo.php ( 2.63 KB )
  123. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-orm/src/db/concern/Transaction.php ( 2.77 KB )
  124. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/driver/File.php ( 5.96 KB )
  125. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/LogHandlerInterface.php ( 0.86 KB )
  126. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/log/Channel.php ( 3.89 KB )
  127. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/event/LogRecord.php ( 1.02 KB )
  128. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-helper/src/Collection.php ( 16.47 KB )
  129. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/facade/View.php ( 1.70 KB )
  130. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/View.php ( 4.39 KB )
  131. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Response.php ( 8.81 KB )
  132. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/response/View.php ( 3.29 KB )
  133. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/Cookie.php ( 6.06 KB )
  134. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-view/src/Think.php ( 8.38 KB )
  135. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/framework/src/think/contract/TemplateHandlerInterface.php ( 1.60 KB )
  136. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/Template.php ( 46.61 KB )
  137. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/driver/File.php ( 2.41 KB )
  138. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-template/src/template/contract/DriverInterface.php ( 0.86 KB )
  139. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/runtime/temp/067d451b9a0c665040f3f1bdd3293d68.php ( 11.98 KB )
  140. /yingpanguazai/ssd/ssd1/www/f.mffb.com.cn/vendor/topthink/think-trace/src/Html.php ( 4.42 KB )
  1. CONNECT:[ UseTime:0.000421s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000694s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000245s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000310s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000573s ]
  6. SELECT * FROM `set` [ RunTime:0.000269s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000617s ]
  8. SELECT * FROM `article` WHERE `id` = 491929 LIMIT 1 [ RunTime:0.003233s ]
  9. UPDATE `article` SET `lasttime` = 1783113551 WHERE `id` = 491929 [ RunTime:0.007274s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.002183s ]
  11. SELECT * FROM `article` WHERE `id` < 491929 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000529s ]
  12. SELECT * FROM `article` WHERE `id` > 491929 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000844s ]
  13. SELECT * FROM `article` WHERE `id` < 491929 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.000908s ]
  14. SELECT * FROM `article` WHERE `id` < 491929 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.002615s ]
  15. SELECT * FROM `article` WHERE `id` < 491929 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.002957s ]
0.090629s