乐于分享
好东西不私藏

4.Spring AI 工具调用:让 AI 模型具备行动能力

4.Spring AI 工具调用:让 AI 模型具备行动能力

字数 3832,阅读大约需 16 分钟

Spring AI 工具调用:让 AI 模型具备行动能力

本文是 Spring AI Agent 开发学习系列的第 4 篇


开篇

前几篇我们让 AI 能"说话",能"结构化输出",但仔细想想——AI 只能生成文本,它没法获取实时数据、没法调用外部 API、没法执行计算。

这就是工具调用(Tool Calling / Function Calling)的价值所在。

读完本文,你将收获

  • • ✅ 理解工具调用的核心原理(模型→工具→模型)
  • • ✅ 使用 @Tool 注解定义工具方法
  • • ✅ 使用 @ToolParam 描述工具参数
  • • ✅ 对比"无工具"与"有工具"的效果差异
  • • ✅ 配套代码验证通过的所有接口

一、什么是工具调用?

工具调用是 AI 模型与外部系统交互的桥梁。

工作流程

用户提问:"北京天气怎么样?"    ↓模型分析:需要天气数据 → 决定调用工具 get_weather("北京")    ↓Spring AI 执行 ToolService.getWeather("北京")    ↓返回结果:"晴,22°C,空气质量:良好"    ↓模型将工具结果组织成自然语言回答用户

没有工具 vs 有工具的对比

用户问题
无工具回答
有工具回答
"现在几点了?"
抱歉,我无法获取实时时间
当前时间:2026-05-31 10:47
"北京天气如何?"
建议查看天气预报 APP
晴,22°C,空气质量良好
"计算 (15+3)*2"
应该是 36
(15+3)*2 = 36 ✅ 实际计算

这就是本质区别:模型从"知识回忆"变成了"能力调用"


二、@Tool 注解详解

Spring AI 2.0.0-M8 的 @Tool 注解定义在 spring-ai-model 中:

@Target(ElementType.METHOD)@Retention(RetentionPolicy.RUNTIME)public @interface Tool {    String name();                    // 工具名称    String description();             // 工具描述(很重要!)    boolean returnDirect() default false;  // 是否直接返回工具结果    Class<? extends ToolCallResultConverter> resultConverter() default ...;}

参数描述使用 @ToolParam

@Target(ElementType.PARAMETER)@Retention(RetentionPolicy.RUNTIME)public @interface ToolParam {    boolean required() default true;    String description();             // 参数描述(模型根据描述来填充值)}

核心设计思想

  1. 1. 描述就是一切@Tool 的 description 和 @ToolParam 的 description 是模型判断何时调用、如何调用的关键
  2. 2. 模型自主决策:不是你调用工具,是模型决定是否调用
  3. 3. name 要见名知意:例如 get_weather 比 tool1 更容易被模型理解

三、实战:构建工具服务

3.1 定义工具类

@Componentpublic class ToolService {    @Tool(name = "get_current_time", description = "获取当前的日期和时间")    public String getCurrentTime() {        return "当前日期:" + LocalDate.now() + ",时间:" + LocalTime.now();    }    @Tool(name = "get_weather", description = "查询指定城市的实时天气")    public String getWeather(            @ToolParam(description = "城市名称,如:北京、上海") String city) {        // 从数据源查询天气...        return city + "天气:晴,22°C";    }    @Tool(name = "calculate", description = "执行数学表达式计算,支持加减乘除和括号")    public String calculate(            @ToolParam(description = "数学表达式") String expression) {        // 执行表达式计算...        return expression + " = " + result;    }    @Tool(name = "search_info", description = "搜索相关信息(模拟搜索引擎)")    public String searchInfo(            @ToolParam(description = "搜索关键词") String keyword) {        // 模拟搜索...        return "搜索结果...";    }}

3.2 注册工具到 ChatClient

Spring AI 2.0.0-M8 提供了灵活的注册方式:

// 方式一:直接传工具实例(最简单)chatClient.prompt()    .user(message)    .tools(toolService)   // ← 自动扫描 @Tool 注解    .call()    .content();// 方式二:使用 ToolSpec 细粒度控制chatClient.prompt()    .user(message)    .tools(t -> t.instances(toolService))    .call()    .content();// 方式三:只启用特定的工具chatClient.prompt()    .user(message)    .toolNames("get_weather", "get_current_time")    .tools(toolService)    .call()    .content();

.tools(Object...) 接受任意带有 @Tool 方法的 Spring Bean,自动扫描并注册

3.3 完整接口一览

本项目部署在 8083 端口,设计了 6 个 REST 端点:

对比实验

#
端点
说明
效果
1
GET /api/tool/chat
聊天(无工具)
模型只能靠知识回答
2
GET /api/tool/chat-with-tools
聊天(有工具)
模型自动调用工具

工具演示

#
端点
说明
示例
3
GET /api/tool/time
获取当前时间
返回精确到秒的实际时间
4
GET /api/tool/weather?city=北京
查询天气
返回城市天气数据
5
GET /api/tool/calculate?expression=(15+3)*2
数学计算
实际执行表达式
6
GET /api/tool/search?keyword=Spring AI
信息搜索
模拟搜索引擎

快速启动

export AI_API_KEY=your-api-key-herecd module-03-tools/01-basic-toolsmvn spring-boot:run# 对比效果curl "http://localhost:8083/api/tool/chat?message=现在几点了?"   # ❌ 无法回答curl "http://localhost:8083/api/tool/time"                       # ✅ 精确时间# 其他工具curl "http://localhost:8083/api/tool/weather?city=北京"curl "http://localhost:8083/api/tool/calculate?expression=(15%2B3)*2"curl "http://localhost:8083/api/tool/search?keyword=Spring+AI"

四、工具调用的完整流程

请求链路

HTTP 请求 → Controller → ChatClient.tools(toolService).call()                                 ↓                     ChatClient 构建 Prompt(含工具定义)                                 ↓                     AI 模型收到请求 + 工具描述(JSON Schema)                                 ↓                     模型决定调用哪个工具 → 返回工具调用请求                                 ↓                     Spring AI 执行 MethodToolCallback                                 ↓                     ToolService.方法() 被执行                                 ↓                     工具结果返回给模型                                 ↓                     模型用工具结果生成最终回答                                 ↓                     HTTP 响应

Spring AI 内部机制

当你调用 .tools(toolService)

  1. 1. MethodToolCallback.Builder 扫描 toolService 的所有方法
  2. 2. 找到带有 @Tool 注解的方法
  3. 3. 提取 namedescription、参数类型和 @ToolParam 描述
  4. 4. 生成 JSON Schema 描述工具签名
  5. 5. 将工具定义作为 Prompt 的一部分发送给模型
  6. 6. 模型返回调用请求 → 执行方法 → 返回结果

五、模型是怎样"看到"工具的?

理解前面的流程后,你可能会好奇:Spring AI 是如何把 Java 方法"翻译"给 AI 模型听的?

答案是通过 JSON Schema

5.1 @Tool 到 JSON Schema 的转换

当你调用 .tools(toolService),Spring AI 内部使用 JsonSchemaGenerator(基于 victools/jsonschema-generator 库)扫描每个 @Tool 方法,生成 JSON Schema 描述。

以 get_weather 方法为例:

@Tool(name = "get_weather", description = "查询指定城市的实时天气情况")public String getWeather(        @ToolParam(description = "城市名称,如:北京、上海、广州") String city) {

生成的 JSON Schema 如下:

{  "$schema": "https://json-schema.org/draft-07/schema#",  "type": "object",  "properties": {    "city": {      "type": "string",      "description": "城市名称,如:北京、上海、广州"    }  },  "required": ["city"],  "additionalProperties":false}

然后 Spring AI 按照 OpenAI 协议包装,最终发给模型的是这样的:

{  "type": "function",  "function": {    "name": "get_weather",    "description": "查询指定城市的实时天气情况",    "parameters": {      "type": "object",      "properties": {        "city": {          "type": "string",          "description": "城市名称,如:北京、上海、广州"        }      },      "required": ["city"]    }  }}

5.2 模型收到了什么

本项目的 ToolService 定义了 4 个工具,所以实际上模型收到的是这样一组描述:

[  {    "name": "get_current_time",    "description": "获取当前的日期和时间",    "parameters": { "type": "object", "properties": {} }  },  {    "name": "get_weather",    "description": "查询指定城市的实时天气情况",    "parameters": {      "type": "object",      "properties": {        "city": { "type": "string", "description": "城市名称,如:北京、上海、广州" }      },      "required": ["city"]    }  },  {    "name": "calculate",    "description": "执行数学表达式计算,支持加减乘除",    "parameters": {      "type": "object",      "properties": {        "expression": { "type": "string", "description": "数学表达式,例如:1 + 2 * 3" }      },      "required": ["expression"]    }  },  {    "name": "search_info",    "description": "搜索相关信息(模拟搜索引擎)",    "parameters": {      "type": "object",      "properties": {        "keyword": { "type": "string", "description": "搜索关键词" }      },      "required": ["keyword"]    }  }]

模型收到用户消息 + 这组 JSON 描述后,会做三件事:

步骤
模型做什么
依据是什么
① 判断是否调工具
分析用户意图是否需要实时数据
模型自身推理能力
② 选择哪个工具
比对用户意图和每个工具的 description
@Tool.description
③ 传入什么参数
从用户消息中提取参数值
@ToolParam.description

这就是"描述即代码"的技术原理——@Tool.description 和 @ToolParam.description 不是写给人类看的注释,而是写给模型看的"使用说明书"

5.3 无参数的工具

像 get_current_time 这样没有参数的方法,生成的 Schema 中 properties 为空对象:

{  "name": "get_current_time",  "description": "获取当前的日期和时间",  "parameters": {    "type": "object",    "properties": {}  }}

模型看到这个描述后,只要判断"用户想知道当前时间",就会直接触发调用,不需要提取任何参数。


六、最佳实践

6.1 描述要准确

// ❌ 差:模糊的描述@Tool(description = "查询天气")public String getWeather(String city)// ✅ 好:明确的描述@Tool(name = "get_weather", description = "查询指定城市的实时天气,包括温度、天气状况、空气质量")public String getWeather(@ToolParam(description = "城市名称,如:北京、上海、广州") String city)

描述越准确,模型越容易在正确时机调用。

6.2 返回值要结构化

工具返回值可以是文本,也可以是 JSON。如果是 JSON,模型会自动解析并使用。

6.3 善用 returnDirect

当工具返回值本身就是最终答案时,使用 returnDirect = true 可以跳过模型重新处理结果的步骤:

@Tool(name = "get_weather", description = "...", returnDirect = true)

6.4 工具粒度要合适

  • • 太粗:一个工具做太多事 → 模型不好判断
  • • 太细:每个小操作都创建一个工具 → 模型选择困难

建议:一个工具对应一个明确的业务能力


📌 核心知识点总结

✅ 掌握内容

  • @Tool 注解:name、description、returnDirect 属性
  • @ToolParam 注解:为参数添加描述信息
  • ChatClient.tools() 注册工具实例
  • 模型自动决策:判断何时、是否调用工具
  • 工具调用完整流程:模型→执行→结果→回答
  • JSON Schema 转换原理:@Tool → 模型收到的 JSON 描述

🔑 关键要点

  1. 1. 模型说了算:不是你调用工具,是模型决定要不要调用
  2. 2. 描述即代码@Tool.description 和 @ToolParam.description 是模型决策的依据——它们被写入 JSON Schema 发给模型
  3. 3. 模型"看到"的是 JSON:@Tool 被转换成 JSON Schema 格式的工具描述,和用户消息一起发给模型
  4. 4. 无参数工具也一样:没有参数的方法也会生成工具定义(properties 为空对象),模型同样可以触发调用
  5. 5. .tools(Object...):最便捷的注册方式,自动扫描 @Tool 注解

🎯 实战能力

读完本文,你应该能够:

  • • ✅ 使用 @Tool 定义自己的工具方法
  • • ✅ 使用 @ToolParam 描述参数,引导模型正确传参
  • • ✅ 将工具注册到 ChatClient 并处理多工具场景
  • • ✅ 理解工具调用流程,能排查工具调用失败的问题

下期预告

第5篇:工具进阶与生态——构建企业级工具框架

我们已经学会了定义工具,但生产环境还需要参数验证、动态注册、安全控制、多工具协调。下期我们深入这些进阶话题。

敬请期待!


快速验证工具调用效果

cd module-03-tools/01-basic-toolsexport AI_API_KEY=your-keymvn spring-boot:run# 先试无工具:curl localhost:8083/api/tool/chat?message=现在几点了# 再试有工具:curl localhost:8083/api/tool/time# 对比差异,秒懂工具调用的价值

关注本系列,系统掌握 Spring AI Agent 开发!🔔

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