乐于分享
好东西不私藏

Spring AI Tool Calling 入门:让 AI 能调用你的业务方法

Spring AI Tool Calling 入门:让 AI 能调用你的业务方法

我见过很多客服 AI,第一版都卡在同一个地方。

用户说:

帮我查一下订单 12345 的物流信息。

模型回答:

抱歉,我无法直接查询订单物流信息。

这不是模型不行。

而是这次调用里,你没有给它“查询订单”的工具。

普通聊天模型只能生成文本。

它不能直接访问你的数据库,也不能绕过应用去调用业务系统。

Tool Calling 要解决的就是这件事:

模型负责判断“要调哪个工具、参数是什么”,Java 应用负责真正执行。

这篇文章,我们用 Spring AI 跑一个最小 Demo:

用户问订单物流,模型自动调用一个 Java 方法,再基于方法返回结果回答。

本文基于 Spring AI 1.1.7,模型使用 DeepSeek,示例配置使用 deepseek-v4-flash

如果你已经有一个能正常调用 ChatClient 的 Spring Boot 项目,大概率 30 分钟就能跑通。

一、先把 Demo 跑起来

这个 Demo 不接真实数据库。

我们先用模拟数据跑通主流程。

真实项目里,再把模拟逻辑换成你的 OrderService

1. 准备依赖

如果你已经有 Spring Boot 项目,先确认至少有两个依赖:

  • spring-boot-starter-web:提供 HTTP 接口;
  • spring-ai-starter-model-deepseek:接入 DeepSeek 聊天模型。

pom.xml 可以这样配置:

xml

<properties>

    <java.version>17</java.version>

    <spring-ai.version>1.1.7</spring-ai.version>

</properties>

<dependencies>

    <dependency>

        <groupId>org.springframework.boot</groupId>

        <artifactId>spring-boot-starter-web</artifactId>

    </dependency>

    <dependency>

        <groupId>org.springframework.ai</groupId>

        <artifactId>spring-ai-starter-model-deepseek</artifactId>

    </dependency>

</dependencies>

<dependencyManagement>

    <dependencies>

        <dependency>

            <groupId>org.springframework.ai</groupId>

            <artifactId>spring-ai-bom</artifactId>

            <version>${spring-ai.version}</version>

            <type>pom</type>

            <scope>import</scope>

        </dependency>

    </dependencies>

</dependencyManagement>

如果你是从 Spring Initializr 新建项目,记得选 Java 17 或以上。

Tool Calling 不需要再额外引入一套复杂依赖。

@Tool@ToolParam.tools(...) 这些能力,Spring AI 的模型 Starter 会把相关模块带进来。

2. 配置 DeepSeek

application.yaml

yaml

spring:

  application:

    name: springai-deepseek-demo

  ai:

    model:

      chat: deepseek

    deepseek:

      api-key: ${DEEPSEEK_API_KEY}

      chat:

        options:

          model: deepseek-v4-flash

          temperature: 0.2

启动前设置环境变量:

bash

export DEEPSEEK_API_KEY="你的 DeepSeek API Key"

如果你用 IDEA 直接运行项目,就在运行配置里加环境变量。

路径是:

text

Edit Configurations...

→ 选择 SpringaiDeepseekDemoApplication

→ Environment variables

→ 新增 DEEPSEEK_API_KEY=你的 DeepSeek API Key

→ Apply / OK

这样 application.yaml 里的 ${DEEPSEEK_API_KEY} 才能读到你的 Key。

这里补充两点。

第一,Spring AI 1.1.7 本地源码里还有 deepseek-chat 这类旧模型名的测试用例。

但 DeepSeek 官方 Change Log 已经在 2026-04-24 标注:API 支持 deepseek-v4-prodeepseek-v4-flash,并且 deepseek-chatdeepseek-reasoner 会在 2026-07-24 后废弃。

所以这篇示例使用 deepseek-v4-flash

第二,模型支持 Tool Calling,不等于它每次都会按你想的方式调用工具。

第一次接入时,先用查询类工具验证。

不要一上来就接退款、发短信、删数据这类高风险操作。

3. 定义一个工具类

新建 OrderTools

java

package com.example.springaideepseekdemo.toolcalling;

import org.springframework.ai.tool.annotation.Tool;

import org.springframework.ai.tool.annotation.ToolParam;

import org.springframework.stereotype.Component;

@Component

public class OrderTools {

    @Tool(description = "根据订单ID查询订单物流信息,返回物流状态和预计送达时间")

    public String queryOrderLogistics(

            @ToolParam(description = "订单ID,5到20位数字") String orderId) {

        if (orderId == null || !orderId.matches("\\d{5,20}")) {

            return "订单ID格式不正确,订单ID应为5到20位数字";

        }

        if ("12345".equals(orderId)) {

            return "订单已发货,当前在北京分拨中心,预计明天送达";

        }

        return "未找到该订单的物流信息";

    }

}

@Tool 表示这个方法可以作为工具暴露给模型。

@ToolParam 用来描述参数。

Spring AI 会根据方法和参数信息生成工具定义,传给模型。

所以描述要写具体。

查询订单 太泛。

根据订单ID查询订单物流信息,返回物流状态和预计送达时间 会清楚很多。

4. 写一个测试接口

新建 OrderController

java

package com.example.springaideepseekdemo.controller;

import com.example.springaideepseekdemo.toolcalling.OrderTools;

import org.springframework.ai.chat.client.ChatClient;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.bind.annotation.RequestParam;

import org.springframework.web.bind.annotation.RestController;

@RestController

public class OrderController {

    private final ChatClient chatClient;

    private final OrderTools orderTools;

    public OrderController(ChatClient.Builder builder, OrderTools orderTools) {

        this.chatClient = builder.build();

        this.orderTools = orderTools;

    }

    @GetMapping("/ask")

    public String ask(@RequestParam String question) {

        return chatClient.prompt()

                .user(question)

                .tools(orderTools)

                .call()

                .content();

    }

}

这里用的是请求级工具:

java

.tools(orderTools)

意思是:这一次请求里,模型能看到 OrderTools 里的工具方法。

权限敏感的工具,建议优先用请求级注册。

如果你用 ChatClient.Builder#defaultTools(...),这些工具会成为这个 ChatClient 的默认工具,影响范围更大。

5. 启动测试

启动应用:

bash

./mvnw spring-boot:run

调用接口:

bash

curl --get "http://localhost:8080/ask" \

  --data-urlencode "question=帮我查一下订单12345的物流"

如果链路跑通,背后大概是这样:

text

用户问题:帮我查一下订单12345的物流

模型选择工具:queryOrderLogistics

工具入参:orderId=12345

工具返回:订单已发货,当前在北京分拨中心,预计明天送达

最终回答:您的订单 12345 已发货,当前在北京分拨中心,预计明天送达。

你没有在 Controller 里写“如果用户想查物流,就调用订单服务”的 if-else。

模型会根据用户问题和工具描述,判断要不要请求调用这个工具。

二、背后到底发生了什么

表面上看,业务代码只有一段:

java

chatClient.prompt()

        .user("帮我查一下订单 12345 的物流")

        .tools(orderTools)

        .call()

        .content();

但执行时,通常会经过这几步:

text

1. ChatClient 把用户问题和工具定义发给模型

2. 模型判断需要调用 queryOrderLogistics

3. 模型返回工具调用请求和参数

4. Spring AI 执行对应 Java 方法

5. 工具结果回传给模型

6. 模型基于结果生成最终回答

所以 Tool Calling 不是模型直接执行代码。

模型只是提出请求:

json

{

  "tool": "queryOrderLogistics",

  "arguments": {

    "orderId": "12345"

  }

}

真正执行方法的是 Spring AI 和你的 Java 应用。

这点很关键。

不要把模型当成系统权限边界。

三、三个核心概念

入门阶段,先记住三个就够了。

1. @Tool

把一个 Java 方法暴露成工具。

默认情况下,如果不指定工具名,Spring AI 会使用方法名。

工具名最好简单、稳定,不要带奇怪字符。

2. @ToolParam

描述工具参数。

在 Spring AI 1.1.7 里,@ToolParamrequired 默认是 true

也就是说,参数默认会被当成必填。

3. ToolCallback

ToolCallback 是 Spring AI 内部的工具抽象。

可以理解成:

给模型看的工具定义 + 真正执行的 Java 调用逻辑。

使用 @Tool 时,Spring AI 会把对象里的工具方法转换成对应的 ToolCallback

这篇先不展开底层 API。

@Tool + .tools(...) 跑通,比一开始研究所有抽象更重要。

四、实战注意事项

Demo 跑通不难,上生产要谨慎。

1. 先用只读工具验证

第一次接入,建议先做查询类工具:

text

查订单

查物流

查库存

查配置

查工单状态

不要一上来就接这些:

text

取消订单

执行退款

修改手机号

发放优惠券

发送通知

删除数据

只读工具风险小。

会改变系统状态的工具,一定要加权限校验、参数校验和二次确认。

2. 工具描述要具体

不好的写法:

java

@Tool(description = "查询订单")

public String query(String id) {

    // ...

}

更好的写法:

java

@Tool(description = "根据订单ID查询订单物流信息,返回物流状态和预计送达时间")

public String queryOrderLogistics(

        @ToolParam(description = "订单ID,5到20位数字") String orderId) {

    // ...

}

工具越多,描述越重要。

模型选工具,主要就靠工具名、工具描述和参数描述。

3. 参数别设计太复杂

工具参数要让模型容易构造。

常见类型就够用:

text

String

Integer / Long / Double

Boolean

简单 POJO

简单列表

如果一个 OrderRequest 里有十几个字段,模型很容易填错。

能拆就拆。

4. 后端必须兜底

不要把工具描述当成安全控制。

你写了“只能取消当前用户的未发货订单”,只是帮助模型理解工具。

真正的校验还要写在业务代码里:

text

当前用户有没有权限?

订单是不是属于这个用户?

订单状态能不能取消?

是否需要二次确认?

模型负责判断,后端负责兜底。

5. 日志要留

工具调用失败很常见。

比如订单不存在、参数格式错误、接口超时、数据库异常。

建议至少记录:

text

调用了哪个工具

关键参数是什么

执行耗时

是否成功

异常摘要

以后用户说“AI 查错订单了”,你才有东西可查。

写在最后

Tool Calling 的本质很简单:

模型请求调用,应用真正执行,再把结果交回模型。

如果你已经有 ChatClient 项目,现在就可以加一个 OrderTools,用 .tools(...) 跑一下。

只要模型真的调用了 Java 方法,并基于工具返回结果回答,Tool Calling 就跑通了。

记住三句话:

text

模型负责判断

工具负责执行

后端负责兜底

RAG 让模型能“查资料”。

Tool Calling 让模型能“调能力”。

这两个组合起来,Agent 才开始从“会聊天”,走向“能做事”。

我是 Dilee,11 年 Java 老兵,专注 AI 落地应用。

这个系列会持续更新,欢迎关注。

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-06-14 22:30:04 HTTP/1.1 GET : https://www.yeyulingfeng.com/a/750072.html
  2. 运行时间 : 0.299330s [ 吞吐率:3.34req/s ] 内存消耗:4,598.41kb 文件加载:145
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=b20a397e83e44b650cd76bdc891cb9b0
  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.001188s ] mysql:host=127.0.0.1;port=3306;dbname=wenku;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001647s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.002763s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.001668s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001400s ]
  6. SELECT * FROM `set` [ RunTime:0.003176s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001783s ]
  8. SELECT * FROM `article` WHERE `id` = 750072 LIMIT 1 [ RunTime:0.020002s ]
  9. UPDATE `article` SET `lasttime` = 1781447404 WHERE `id` = 750072 [ RunTime:0.026679s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 64 LIMIT 1 [ RunTime:0.025644s ]
  11. SELECT * FROM `article` WHERE `id` < 750072 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.002222s ]
  12. SELECT * FROM `article` WHERE `id` > 750072 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.003991s ]
  13. SELECT * FROM `article` WHERE `id` < 750072 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.000887s ]
  14. SELECT * FROM `article` WHERE `id` < 750072 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.000798s ]
  15. SELECT * FROM `article` WHERE `id` < 750072 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.001147s ]
0.303263s