当前位置:首页>python>Claude-Code-python 前端改造项目工作流程详解

Claude-Code-python 前端改造项目工作流程详解

  • 2026-06-27 23:24:20
Claude-Code-python 前端改造项目工作流程详解

文章目录

    • 1. 项目概述
    • 2. 完整流程(用户输入 → 最终输出)
      • 第 1 步:入口点与初始化 (`src/tui/app.py`)
      • 第 2 步:用户输入处理
      • 第 3 步:查询执行 (`src/tui/query.py`)
      • 第 4 步:引擎核心 (`src/core/engine.py`)
      • 第 5 步:LLM 客户端 (`src/core/llm.py`)
    • 3. 提示词构建逻辑
      • 系统提示 (`src/core/context.py`)
      • 计划模式提示注入
    • 4. 工具选择与执行机制
      • 工具基类 (`src/core/tool.py`)
      • 工具注册与模式
      • 工具执行流程 (`src/core/engine.py`)
    • 5. 代码文件与关键函数参考
    • 6. 示例用户旅程
    • 7. 技能系统
      • 技能发现与注册
      • 技能提示注入
      • 内置技能示例
    • 8. 记忆系统层级结构
      • 8.1 存储层(底层)
      • 8.2 提取层(实时层)
      • 8.3 整合层(梦境层)
      • 表格转换结果
      • 8.4 访问层(接口层)
    • 9. 上下文压缩系统层级结构
      • 9.1 监控层
      • 9.2 拆分层
      • 9.3 处理层
      • 9.4 压缩层
      • 9.5 重组层
    • 10. 记忆与压缩系统协作关系
      • 维度对比表格
    • 11. 工作模式总结
      • 正常工作模式
      • 计划模式
 本文档对 claude-code-python 项目架构进行全面剖析,重点关注用户输入在系统中的完整流转过程。完整流程: 页面设计: 

1. 项目概述

claude-code-python 是一个用 Python 构建的极简 claude-code AI 编程助手。在节省token方面,做了改造,解决用户输入你好,就要花几w token的问题,项目具有以下特性:

  • 基于 prompt_toolkit 和 Rich 的交互式命令行界面(TUI)

  • 支持与大语言模型(Anthropic Claude / OpenAI)进行工具化交互

  • 计划模式,用于实现前探索

  • 带"梦境"整合的记忆系统

  • 伙伴(buddy)陪伴功能

  • 成本追踪与会话管理

2. 完整流程(用户输入 → 最终输出)

第 1 步:入口点与初始化 (src/tui/app.py)

应用从 app.py:107 的 main() 函数启动。它会:

  1. 解析命令行参数 (app.py:108-138)

  2. 加载配置 (app.py:141)

  3. 初始化沙箱、记忆、技能系统

  4. 设置 Engine,配置工具和系统提示 (app.py:268-282)

  5. 进入交互式 REPL 循环 (app.py:461)

第 2 步:用户输入处理

在交互式 REPL 中:

  • 用户通过 bordered_prompt() 输入内容 (app.py:483-490)

  • 使用 parse_input() 解析输入 (app.py:634)

  • 如果是命令(/help/buddy 等),通过 parse_command() 和 handle_command() 处理 (app.py:537-585)

  • 否则,进入 run_query() 流程 (app.py:634)

第 3 步:查询执行 (src/tui/query.py)

run_query() (query.py:21-145) 协调整个回合:

  • 设置 EscListener 用于取消操作

  • 启动加载指示器

  • 调用 engine.submit(user_input) 并遍历事件:

    • "text"
      : 通过 StreamingMarkdown 流式输出到控制台
    • "waiting"
      : 显示加载指示器
    • "tool_call"
      : 预览工具调用
    • "tool_executing"
      : 更新加载指示器
    • "tool_result"
      : 显示成功/失败状态

第 4 步:引擎核心 (src/core/engine.py)

Engine.submit() (engine.py:195-432) 是主循环:

  1. 将用户消息添加到 self._messages (engine.py:211-215)

  2. 进入 API 调用重试循环 (engine.py:226-315)

  3. 通过 self._client.stream_messages() 调用 LLM (engine.py:237)

  4. 处理流式文本和最终消息

  5. 如果存在 tool_use 块:

    • 分批处理工具(只读工具并行执行)(engine.py:333-341)
    • 为每个工具检查权限
    • 通过 self._execute_tool() 执行工具 (engine.py:434-472)
    • 将工具结果添加到消息中 (engine.py:425-429)
    • 带着更新后的消息循环回到 LLM

第 5 步:LLM 客户端 (src/core/llm.py)

LLMClient (llm.py:112-226) 处理 API 通信:

  • 同时支持 Anthropic 和 OpenAI 提供商

  • stream_messages() 返回 _AnthropicStream 或 _OpenAIStream

  • 将响应标准化为统一格式

3. 提示词构建逻辑

系统提示 (src/core/context.py)

build_system_prompt() (context.py:288-321) 组装以下部分:

  1. 静态部分

    • _get_intro_section()
      : 基础代理指令
    • _get_system_section()
      : 系统规则
    • _get_doing_tasks_section()
      : 软件工程任务指导
    • _get_actions_section()
      : 可逆性/影响范围考量
    • _get_using_tools_section()
      : 工具使用偏好
    • _get_tone_and_style_section()
      : 沟通风格
    • _get_output_efficiency_section()
      : 简洁性准则
  2. 动态部分

    • _get_env_section()
      : 当前工作目录、平台、Git 状态、模型
    • _get_git_section()
      : Git 分支/状态/日志
    • _get_claude_md_section()
      : 项目特定的 CLAUDE.md
    • 记忆系统部分(如启用)
    • 伙伴介绍(如启用)
    • 技能部分(如有)

计划模式提示注入

当处于计划模式时 (features/plan.py):

  • PlanModeManager.enter() (plan.py:110-178) 保存原始状态

  • 将 get_plan_mode_section() 注入到系统提示中 (plan.py:166-168)

  • 切换到只读工具 + 计划工具

4. 工具选择与执行机制

工具基类 (src/core/tool.py)

所有工具都继承自抽象 Tool 类 (tool.py:13-41):

class Tool(ABC):    @property    @abstractmethod    def name(self) -> str: ...    @property    @abstractmethod    def description(self) -> str: ...    @property    @abstractmethod    def input_schema(self) -> dict: ...    @abstractmethod    def execute(self, **kwargs) -> ToolResult: ...

工具注册与模式

  • 工具在 app.py 中通过 _build_tools_for_mode() 注册

  • 每个工具的 to_api_schema() 转换为 LLM 兼容格式

  • 模式包含 namedescriptioninput_schema

工具执行流程 (src/core/engine.py)

  1. LLM 返回 tool_use 块

  2. 引擎分批处理工具 (engine.py:333-341):

    • 只读工具:并行执行(ThreadPoolExecutor
    • 非只读工具:顺序执行
  3. 对于每个工具:

    • 发出 "tool_call" 事件
    • 通过 PermissionChecker 检查权限
    • 如获批准,发出 "tool_executing" 并调用 tool.execute(**input)
    • 发出带有 ToolResult 的 "tool_result"
  4. 将 tool_result 块添加到消息中并循环回到 LLM

5. 代码文件与关键函数参考

阶段
文件
关键函数
入口点src/tui/app.pymain()
 (107)、交互式循环 (461)
输入处理src/tui/query.pyrun_query()
 (21)
引擎核心src/core/engine.pyEngine.submit()
 (195)、Engine._execute_tool() (434)
LLM 客户端src/core/llm.pyLLMClient.stream_messages()
 (163)
系统提示src/core/context.pybuild_system_prompt()
 (288)
工具基类src/core/tool.pyTool
 抽象类
计划模式src/features/plan.pyPlanModeManager.enter()
 (110)、PlanModeManager.exit() (180)
计划工具src/tools/plan_tools.pyEnterPlanModeTool
ExitPlanModeTool

6. 示例用户旅程

让我们通过一个简单的交互来完整走一遍流程:

  1. 用户输入:“读取 README.md”

  2. app.py:REPL 获取输入,调用 parse_input(),然后调用 run_query(engine, "读取 README.md")

  3. query.py:设置监听器,调用 engine.submit("读取 README.md")

  4. engine.py

    • 添加用户消息
    • 使用系统提示 + 消息调用 LLM
    • LLM 决定使用 Read 工具,参数为 {"file_path": "README.md"}
    • 引擎执行 FileReadTool.execute()
    • 将工具结果添加到消息
    • 带着更新后的消息再次调用 LLM
    • LLM 生成自然语言摘要
  5. query.py:将摘要流式输出到控制台

  6. app.py:触发伙伴观察者、提取记忆标签等

7. 技能系统

技能(Skills)是预定义的专业能力,用于处理特定类型的任务。

技能发现与注册

  • 在 app.py:155-158 初始化: 
    • register_bundled_skills()
       注册内置技能
    • discover_skills(cwd)
       发现项目/用户技能
    • build_skills_prompt_section()
       构建技能提示部分

技能提示注入

技能信息会被添加到系统提示中(app.py:174-175),使 LLM 了解可用的专业能力。

内置技能示例

项目包含多个预定义技能:

  • LifeWisdomGuide
    : 基于 100+ 经典生活故事的逆向思维与处世智慧
  • ai-life-post-writer
    : 撰写贴近生活的 AI 个人故事帖子
  • frontend-design
    : 创建高质量的前端界面

8. 记忆系统层级结构

记忆系统采用 4 层架构,基于 src/features/memory.py 实现:

8.1 存储层(底层)

文件系统结构

  • 每日日志
    logs/YYYY/MM/YYYY-MM-DD.md - 追加式时间戳记录
  • 记忆索引
    MEMORY.md - 不超过 200 行的索引文件,只包含链接+简短描述
  • 结构化记忆文件
    *.md - 带 frontmatter 的记忆文件(name/description/type)
  • 会话持久化
    sessions/SESSION_ID.jsonl - JSONL 格式的完整会话记录

关键函数

  • ensure_memory_dir()
     - 创建目录结构
  • daily_log_path()
     - 生成每日日志路径
  • save_session()
     / load_session() - 会话持久化

8.2 提取层(实时层)

实时记忆捕获

  • <memory> 标签提取
    extract_memory_tags() 自动从 LLM 响应中提取
  • 追加机制
    append_to_daily_log() 将提取的内容时间戳化后追加到当日日志

在 app.py 中的集成(第 688-690 行):

# Post-turn: extract <memory> tagstext = engine.last_assistant_text()for mem in extract_memory_tags(text):    append_to_daily_log(memory_dir, mem)

8.3 整合层(梦境层)

4 阶段梦境整合流程

表格转换结果

阶段
功能
关键操作
Phase 1 - Orient
定向
Glob 列文件、读 MEMORY.md、浏览现有记忆
Phase 2 - Gather recent signal
收集信号
优先看每日日志、然后是漂移的记忆、最后是会话记录
Phase 3 - Consolidate
整合
合并新信号到现有文件、转换相对日期为绝对日期、删除矛盾事实
Phase 4 - Prune and index
修剪索引
更新 MEMORY.md(<200 行、<25KB)、移除过期指针、添加新记忆

并发控制

  • 锁文件:.consolidate-lock - 记录持有者 PID
  • 锁过期:1 小时后自动回收
  • 扫描节流:10 分钟内不重复扫描会话

自动触发条件should_auto_dream()):

  • 时间 ≥ min_hours(默认 24 小时)
  • 新会话数 ≥ min_sessions(默认 5 个)

8.4 访问层(接口层)

系统提示注入build_memory_system_section() - 将记忆系统指令和 MEMORY.md 内容注入到系统提示中

4 种记忆类型

类型
用途
何时保存
user
用户信息
了解用户角色、偏好、职责时
feedback
用户反馈
用户纠正方法时(最重要)
project
项目信息
了解谁在做什么、为什么、截止日期时
reference
参考资源
了解外部系统资源位置时

命令接口

  • /dream
     - 手动触发梦境整合
  • /remember <text>
     - 手动追加记忆
  • /memory
     - 显示当前 MEMORY.md

9. 上下文压缩系统层级结构

上下文压缩系统采用 5 层架构,基于 src/features/compact.py 实现:

9.1 监控层

阈值判断

模型
上下文窗口
自动压缩阈值
Claude Opus 4.x
1,000,000 tokens
~967,000 tokens
Claude Sonnet 4.x
1,000,000 tokens
~967,000 tokens
Claude 3.x
200,000 tokens
~127,000 tokens

关键函数

  • estimate_tokens()
     - 粗略估算(字符数 / 4)
  • should_compact()
     - 判断是否需要压缩(优先用 API 返回的实际 token 数)

在 app.py 中的集成(第 595-605 行):

# Auto-compact when approaching token limitsifshould_compact(engine.get_messages(), model=app_config.model,                 last_input_tokens=cost_tracker.last_input_tokens):    console.print("[dim]Auto-compacting conversation…[/dim]")    try:        new_msgs, _ = compact_service.compact(...)        engine.set_messages(new_msgs)    ...

9.2 拆分层

消息智能拆分_split_recent()):

保留约束
最少消息数
6 条
最少 token 数
10,000 tokens
不拆分
tool_use / tool_result 配对

拆分逻辑

  • 从后往前遍历,累加保留的消息和 token
  • 达到双约束后停止
  • 如果切分点落在纯 tool_result 的用户消息上,往前多切一条(包含 tool_use)

9.3 处理层

预处理操作

操作
函数
目的
媒体剥离
_strip_media()
将 image/document 块替换为 [image]/[document] 标记,节省 token
角色交替修复
_fix_alternation()
确保严格 user/assistant 交替,合并连续同角色消息

9.4 压缩层

LLM 摘要生成

固定提示结构COMPACT_PROMPT):

章节
内容
Primary Request
用户总体目标
Key Technical Concepts
重要技术细节、模式、框架、约束
Files and Code
讨论/修改的关键文件及操作
Errors and Fixes
遇到的错误及解决方案
Current Work
最近工作及状态
Pending Tasks
未完成的任务和下一步

系统提示COMPACT_SYSTEM):

  • “你是一个对话摘要器。按照用户要求的格式生成结构化、详细的摘要。”

9.5 重组层

新消息列表构建

[用户:摘要消息]  ↓[助手:确认消息]  ↓[近期保留的消息(6条+)]

摘要消息格式

[This is a summary of the conversation so far — the original messages have been compacted to save context space.][结构化摘要内容]

10. 记忆与压缩系统协作关系

维度对比表格

维度
上下文压缩
记忆系统
时间范围
当前会话
跨会话长期
触发方式
自动(token 阈值)
手动 / 自动(时间+会话数)
数据格式
摘要消息
结构化文件 + 索引
目的
节省上下文空间
累积持久知识

11. 工作模式总结

正常工作模式

  1. 用户输入 → 解析 → run_query()

  2. Engine.submit() 添加消息 → 调用 LLM

  3. LLM 生成响应(可能包含工具调用)

  4. 执行工具 → 添加结果 → 再次调用 LLM

  5. 循环直到无工具调用

  6. 输出最终响应

计划模式

  1. 用户触发计划模式 → EnterPlanModeTool 调用

  2. PlanModeManager 保存状态 → 注入计划提示 → 切换到只读工具

  3. LLM 探索代码库 → 编写计划文件

  4. 用户确认计划 → ExitPlanModeTool 调用

  5. 恢复原始状态 → 开始执行计划

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-07-03 06:28:10 HTTP/2.0 GET : https://f.mffb.com.cn/a/498421.html
  2. 运行时间 : 0.191057s [ 吞吐率:5.23req/s ] 内存消耗:4,743.13kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=062b17a4af3b97dbb758e412baa450f9
  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.000826s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000588s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.008024s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000483s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000748s ]
  6. SELECT * FROM `set` [ RunTime:0.000260s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000710s ]
  8. SELECT * FROM `article` WHERE `id` = 498421 LIMIT 1 [ RunTime:0.005985s ]
  9. UPDATE `article` SET `lasttime` = 1783031291 WHERE `id` = 498421 [ RunTime:0.011931s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.002779s ]
  11. SELECT * FROM `article` WHERE `id` < 498421 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.012267s ]
  12. SELECT * FROM `article` WHERE `id` > 498421 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.010517s ]
  13. SELECT * FROM `article` WHERE `id` < 498421 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.009018s ]
  14. SELECT * FROM `article` WHERE `id` < 498421 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.001567s ]
  15. SELECT * FROM `article` WHERE `id` < 498421 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.004662s ]
0.192835s