乐于分享
好东西不私藏

深入剖析MyBatis插件机制:从自定义插件到PageHelper分页原理(附源码)

深入剖析MyBatis插件机制:从自定义插件到PageHelper分页原理(附源码)

关键词:MyBatis, 插件机制, Interceptor, 动态代理, PageHelper, 分页原理


在日常的开发工作中,你是否遇到过这样的需求:想要在 SQL 执行前后添加一些通用逻辑,比如分页、日志记录、性能监控、数据脱敏等?如果每次都修改业务代码,不仅重复劳动,还容易造成代码混乱。MyBatis 的插件机制正是为了解决这类问题的利器。本文将从自定义插件的实现讲起,深入剖析其底层原理(JDK 动态代理),并以 PageHelper 为例,带你彻底搞懂分页插件的工作机制。


📑 目录

  • 一、MyBatis 插件简介
  • 二、自定义插件实战
    • 2.1 创建 Interceptor 实现类
    • 2.2 配置拦截器
    • 2.3 运行程序
  • 三、插件实现原理深度解析
    • 3.1 初始化操作
    • 3.2 代理对象的创建
    • 3.3 执行流程详解
    • 3.4 多拦截器执行顺序
  • 四、PageHelper 分页插件原理
    • 4.1 PageHelper 的基本使用
    • 4.2 实现原理剖析
  • 五、应用场景分析
  • 六、总结

一、MyBatis 插件简介

插件是一种常见的扩展方式,大多数开源框架也都支持用户通过添加自定义插件的方式来扩展或者改变原有的功能。MyBatis 中也提供的有插件,虽然叫插件,但是实际上是通过**拦截器(Interceptor)**实现的。

在 MyBatis 的插件模块中涉及到两种重要的设计模式:

  1. 责任链模式
    :多个插件按顺序执行
  2. JDK 动态代理
    :实现方法的拦截和增强

这两种设计模式的技术知识是大家要掌握的,也是理解 MyBatis 插件机制的基础。


二、自定义插件实战

下面我们来看下如何实现一个自定义的插件。

2.1 创建 Interceptor 实现类

我们创建的拦截器必须要实现 Interceptor 接口,该接口的定义如下:

public interface Interceptor {  // 执行拦截逻辑的方法  Object intercept(Invocation invocation) throws Throwable;  // 决定是否触发 intercept() 方法  default Object plugin(Object target) {    return Plugin.wrap(target, this);  }  // 根据配置初始化 Intercept 对象  default void setProperties(Properties properties) {    // NOP  }}

在 MyBatis 中,Interceptor 允许拦截的内容是:

目标对象
可拦截的方法
Executor
update, query, flushStatements, commit, rollback, getTransaction, close, isClosed
ParameterHandler
getParameterObject, setParameters
ResultSetHandler
handleResultSets, handleOutputParameters
StatementHandler
prepare, parameterize, batch, update, query

我们创建一个拦截 Executor 中的 query 和 close 方法的示例:

package com.boboedu.interceptor;import org.apache.ibatis.executor.Executor;import org.apache.ibatis.mapping.MappedStatement;import org.apache.ibatis.plugin.*;import org.apache.ibatis.session.ResultHandler;import org.apache.ibatis.session.RowBounds;import java.util.Properties;/** * 自定义的拦截器 * @Signature 注解表示一个方法签名,唯一确定一个方法 */@Intercepts({        @Signature(                type = Executor.class // 需要拦截的类型                , method = "query"     // 需要拦截的方法                // args 中指定被拦截方法的参数列表                , args = {MappedStatement.classObject.classRowBounds.classResultHandler.class}        ),        @Signature(                type = Executor.class                , method = "close"                , args = {boolean.class}        )})public class FirstInterceptor implements Interceptor {    private int testProp;    /**     * 执行拦截逻辑的方法     */    @Override    public Object intercept(Invocation invocation) throws Throwable {        System.out.println("FirstInterceptor 拦截之前 ....");        Object obj = invocation.proceed(); // 执行目标方法        System.out.println("FirstInterceptor 拦截之后 ....");        return obj;    }    /**     * 决定是否触发 intercept 方法     */    @Override    public Object plugin(Object target) {        return Plugin.wrap(target, this);    }    @Override    public void setProperties(Properties properties) {        System.out.println("---->" + properties.get("testProp"));    }    // getter & setter    public int getTestProp() {        return testProp;    }    public void setTestProp(int testProp) {        this.testProp = testProp;    }}

关键点说明

  • @Intercepts
    :声明这是一个拦截器
  • @Signature
    :定义要拦截的方法签名,包含 type(目标类)、method(方法名)、args(参数类型)
  • intercept()
    :核心方法,编写拦截逻辑
  • invocation.proceed()
    :调用目标方法,继续执行链

2.2 配置拦截器

创建好自定义的拦截器后,需要在 MyBatis 全局配置文件中注册:

<plugins>    <plugininterceptor="com.bobo.interceptor.FirstInterceptor">        <propertyname="testProp"value="1000"/>    </plugin></plugins>

2.3 运行程序

执行查询操作进行测试:

@Testpublic void test1() throws Exception {    // 1. 获取配置文件    InputStream in = Resources.getResourceAsStream("mybatis-config.xml");    // 2. 加载解析配置文件并获取 SqlSessionFactory 对象    SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in);    // 3. 根据 SqlSessionFactory 对象获取 SqlSession 对象    SqlSession sqlSession = factory.openSession();    // 4. 通过 SqlSession 中提供的 API 方法来操作数据库    List<User> list = sqlSession.selectList("com.bobo.mapper.UserMapper.selectUserList");    for (User user : list) {        System.out.println(user);    }    // 5. 关闭会话    sqlSession.close();}

运行后,控制台会输出:

FirstInterceptor 拦截之前 ....FirstInterceptor 拦截之后 ....

三、插件实现原理深度解析

自定义插件的步骤虽然简单,但背后的实现原理却很精妙。下面我们来深入分析。

3.1 初始化操作

首先,我们来看下全局配置文件加载解析时做了什么操作。

MyBatis 会解析 <plugins> 标签,对应的代码逻辑如下:

private void pluginElement(XNode parent) throws Exception {    if (parent != null) {        for (XNode child : parent.getChildren()) {            // 获取 <plugin> 节点的 interceptor 属性的值            String interceptor = child.getStringAttribute("interceptor");            // 获取 <plugin> 下的所有的 properties 子节点            Properties properties = child.getChildrenAsProperties();            // 获取 Interceptor 对象            Interceptor interceptorInstance = (Interceptor) resolveClass(interceptor)                    .getDeclaredConstructor().newInstance();            // 设置 interceptor 的属性            interceptorInstance.setProperties(properties);            // Configuration 中记录 Interceptor            configuration.addInterceptor(interceptorInstance);        }    }}

该方法用来解析全局配置文件中的 plugins 标签,然后创建对应的 Interceptor 对象,并封装属性信息。最后调用了 Configuration 对象中的方法:

public void addInterceptor(Interceptor interceptor) {    interceptorChain.addInterceptor(interceptor);}

InterceptorChain 是拦截器链,负责管理所有的拦截器:

public class InterceptorChain {    // 保存所有的 Interceptor    private final List<Interceptor> interceptors = new ArrayList<>();    public Object pluginAll(Object target) {        for (Interceptor interceptor : interceptors) {            target = interceptor.plugin(target); // 创建对应的拦截器的代理对象        }        return target;    }    public void addInterceptor(Interceptor interceptor) {        interceptors.add(interceptor);    }    public List<InterceptorgetInterceptors() {        return Collections.unmodifiableList(interceptors);    }}

3.2 代理对象的创建

在解析时创建了对应的 Interceptor 对象并保存在 InterceptorChain 中,那么这个拦截器是如何和目标对象关联的呢?

可拦截的四个核心对象

  • Executor(SQL 执行器)
  • ParameterHandler(参数处理器)
  • ResultSetHandler(结果集处理器)
  • StatementHandler(SQL 语句处理器)

这些对象在创建时都会调用 pluginAll() 方法:

// Executor 创建时的代码示例executor = (Executor) interceptorChain.pluginAll(executor);// StatementHandler 创建时的代码示例statementHandler = (StatementHandler) interceptorChain.pluginAll(statementHandler);

进入 plugin() 方法,默认实现是:

default Object plugin(Object target) {    return Plugin.wrap(target, this);}

然后进入 Plugin 工具类的 wrap() 方法:

/** * 创建目标对象的代理对象 * 目标对象:Executor、ParameterHandler、ResultSetHandler、StatementHandler */public static Object wrap(Object target, Interceptor interceptor) {    // 获取用户自定义 Interceptor 中 @Signature 注解的信息    Map<Class<?>, Set<Method>> signatureMap = getSignatureMap(interceptor);    // 获取目标类型    Class<?> type = target.getClass();    // 获取目标类型实现的所有接口    Class<?>[] interfaces = getAllInterfaces(type, signatureMap);    // 如果目标类型有实现的接口,就创建代理对象    if (interfaces.length > 0) {        return Proxy.newProxyInstance(            type.getClassLoader(),            interfaces,            new Plugin(target, interceptor, signatureMap));    }    // 否则原封不动地返回目标对象    return target;}

Plugin 类的核心方法

public classPluginimplementsInvocationHandler{    private final Object target;           // 目标对象    private final Interceptor interceptor; // 拦截器    private final Map<Class<?>, Set<Method>> signatureMap; // 记录 @Signature 注解的信息    @Override    public Object invoke(Object proxy, Method methodObject[] argsthrowsThrowable{        try {            // 获取当前方法所在类或接口中,可被当前 Interceptor 拦截的方法            Set<Method> methods = signatureMap.get(method.getDeclaringClass());            if (methods != null && methods.contains(method)) {                // 当前调用的方法需要被拦截,执行拦截操作                return interceptor.intercept(new Invocation(target, methodargs));            }            // 不需要拦截,则调用目标对象中的方法            return method.invoke(target, args);        } catch (Exception e) {            throw ExceptionUtil.unwrapThrowable(e);        }    }}

流程图解析

请求 -> Executor.query() -> Plugin.invoke() ->     是否需要拦截?    ├── 是 -> FirstInterceptor.intercept() -> invocation.proceed() -> 目标方法    └── 否 -> 直接执行目标方法

3.3 执行流程详解

以 Executor 的 query 方法为例,当查询请求到来时:

  1. 调用 executor.query() 方法(实际调用的是代理对象的方法)
  2. 触发 Plugin.invoke() 方法
  3. 在 invoke() 中判断是否需要拦截
  4. 如果需要拦截,执行自定义的 intercept() 方法
  5. 在 intercept() 中通过 invocation.proceed() 调用目标方法
  6. 返回结果

3.4 多拦截器执行顺序

如果配置了多个拦截器,执行顺序是怎样的呢?

配置顺序和执行顺序的关系

  • InterceptorChain 的 List 按照配置从上到下的顺序解析、添加
  • 创建代理时也是按照 List 的顺序代理
  • 执行时是从最后代理的对象开始
    (即配置顺序和执行顺序相反

例如,配置了两个拦截器:Interceptor1、Interceptor2

配置顺序:Interceptor1 -> Interceptor2执行顺序:Interceptor2 -> Interceptor1

相关对象作用总结

对象
作用
Interceptor
自定义插件需要实现的接口
InterceptorChain
配置的插件解析后保存在 Configuration 中
Plugin
触发管理类,用于创建代理对象
Invocation
对被代理类进行包装,可调用 proceed() 执行被拦截的方法

四、PageHelper 分页插件原理

PageHelper 是 MyBatis 中最常用的分页插件。我们来看看它的实现原理。

4.1 PageHelper 的基本使用

添加依赖

<dependency>    <groupId>com.github.pagehelper</groupId>    <artifactId>pagehelper</artifactId>    <version>4.1.6</version></dependency>

配置插件

<plugininterceptor="com.github.pagehelper.PageHelper">    <propertyname="dialect"value="mysql" />    <propertyname="offsetAsPageNum"value="true" />    <propertyname="rowBoundsWithCount"value="true" />    <propertyname="pageSizeZero"value="true" />    <propertyname="reasonable"value="false" /></plugin>

使用示例

// 设置分页参数PageHelper.startPage(15);// 执行查询List<User> list = userMapper.selectUserList();

就是这么简单!一行代码就实现了分页。

4.2 实现原理剖析

PageHelper 同样实现了 Interceptor 接口:

@Intercepts({    @Signature(type = Executor.class, method = "query", ...)})public class PageHelper implements Interceptor {    // ...}

核心拦截逻辑

public Object intercept(Invocation invocation) throws Throwable {    if (autoRuntimeDialect) { // 多数据源        SqlUtil sqlUtil = getSqlUtil(invocation);        return sqlUtil.processPage(invocation);    } else { // 单数据源        if (autoDialect) {            initSqlUtil(invocation);        }        return sqlUtil.processPage(invocation);    }}

SqlUtil 的作用

  • 数据库类型专用的 SQL 工具类
  • 一个数据库 URL 对应一个 SqlUtil 实例
  • 内部有一个 Parser 对象(如 MySQL 对应 MysqlParser)
  • 负责执行 count 查询、分页查询、保存 Page 对象等

Parser 创建

public static Parser newParser(Dialect dialect) {    Parser parser = null;    switch (dialect) {        case mysql:        case mariadb:        case sqlite:            parser = new MysqlParser();            break;        case oracle:            parser = new OracleParser();            break;        case sqlserver:            parser = new SqlServerParser();            break;        // ... 其他数据库方言    }    return parser;}

分页 SQL 的生成

@Overrideprotected BoundSql getPageBoundSql(Object parameterObject) {    String tempSql = sql;    String orderBy = PageHelper.getOrderBy();    if (orderBy != null) {        tempSql = OrderByParser.converToOrderBySql(sql, orderBy);    }    // 根据方言生成对应的分页 SQL    tempSql = localParser.get().getPageSql(tempSql);    return new BoundSql(configuration, tempSql, ...);}

MySQL 最终生成的分页 SQL:

SELECT * FROM user LIMIT ?, ?

五、应用场景分析

MyBatis 插件可以应用于多种场景:

应用场景
描述
实现方式
水平分表
按月度拆分费用表(如 fee_202001 ~ fee_202012)
对 query/update 方法拦截,根据条件修改表名
数据脱敏
手机号中间四位、身份证号出生日期脱敏
对 query 方法拦截,对结果集脱敏处理
菜单权限控制
不同用户展示不同菜单
对 query 方法拦截,根据用户权限添加过滤条件
黑白名单
禁止执行某些危险 SQL(如 like %%)
对 Executor 的 update/query 方法拦截,检查 SQL
全局唯一 ID
高并发环境下生成唯一 ID
拦截 insert 方法,通过雪花算法生成 ID

六、总结

本文从自定义插件的实现入手,深入剖析了 MyBatis 插件机制的核心原理:

  1. 插件本质
    :通过 Interceptor 接口和 JDK 动态代理实现方法拦截
  2. 可拦截对象
    :Executor、ParameterHandler、ResultSetHandler、StatementHandler
  3. 执行流程
    :解析配置 → 创建拦截器 → 创建代理对象 → 调用时判断拦截 → 执行自定义逻辑
  4. 多拦截器顺序
    :配置顺序和执行顺序相反
  5. PageHelper 原理
    :通过拦截 Executor.query(),动态生成分页 SQL

使用建议

  • 合理使用插件,避免过多插件影响性能
  • 注意拦截器的执行顺序,避免逻辑冲突
  • 分页插件建议使用最新版本,支持更多数据库和特性

希望这篇文章能帮助你深入理解 MyBatis 的插件机制,在实际项目中灵活运用!


💡 温馨提示:如果文章对你有帮助,欢迎点赞、收藏、关注!有任何问题欢迎在评论区留言讨论。


参考资源

  • MyBatis 官方文档:https://mybatis.org/mybatis-3/
  • PageHelper GitHub:https://github.com/pagehelper/Mybatis-PageHelper
基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-06-20 15:09:30 HTTP/1.1 GET : https://www.yeyulingfeng.com/a/772015.html
  2. 运行时间 : 0.098336s [ 吞吐率:10.17req/s ] 内存消耗:4,849.33kb 文件加载:145
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=f3fa9915fd687f2a6fab52cdf022e6fd
  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.000581s ] mysql:host=127.0.0.1;port=3306;dbname=wenku;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000767s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000334s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000300s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000595s ]
  6. SELECT * FROM `set` [ RunTime:0.000230s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000666s ]
  8. SELECT * FROM `article` WHERE `id` = 772015 LIMIT 1 [ RunTime:0.000728s ]
  9. UPDATE `article` SET `lasttime` = 1781939370 WHERE `id` = 772015 [ RunTime:0.000870s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 64 LIMIT 1 [ RunTime:0.000265s ]
  11. SELECT * FROM `article` WHERE `id` < 772015 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000458s ]
  12. SELECT * FROM `article` WHERE `id` > 772015 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000375s ]
  13. SELECT * FROM `article` WHERE `id` < 772015 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.003668s ]
  14. SELECT * FROM `article` WHERE `id` < 772015 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.002910s ]
  15. SELECT * FROM `article` WHERE `id` < 772015 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.001232s ]
0.100175s