乐于分享
好东西不私藏

07 | Vite插件系统全解析:从 Hook 到 Pipeline 的设计艺术

07 | Vite插件系统全解析:从 Hook 到 Pipeline 的设计艺术

07 | 插件系统全解析:从 Hook 到 Pipeline 的设计艺术

Vite 深度系列 · 第二阶段 · 技术实现深挖
预计阅读:8 分钟 | 难度:⭐⭐⭐

核心问题:Vite 插件系统如何做到「写一次,开发和构建都能用」?


摘要

Vite 的插件系统是它最精巧的设计之一——兼容 Rollup 插件 API,同时扩展了开发时专有钩子,让一个插件同时服务 Dev 和 Build 两种模式。Vite 8 的 Rolldown 统一引擎更进一步:通过 hookFilter 减少 Rust/JS 通信开销,插件性能提升显著。本文从 PluginContainer 到 HookPipeline,逐层拆解 Vite 插件的执行模型。


1. 插件系统架构总览

1.1 三层架构

┌─────────────────────────────────────────┐
│             Vite Plugin System          │
├─────────────────────────────────────────┤
│  PluginContainer                        │
│  ├── 管理插件注册与排序                  │
│  ├── 分发钩子调用                        │
│  └── 维护插件上下文                      │
├─────────────────────────────────────────┤
│  HookPipeline                           │
│  ├── Sequential(串行):configResolved  │
│  ├── Parallel(并行):load / transform  │
│  └── First(首个命中):resolveId        │
├─────────────────────────────────────────┤
│  Plugin Execution                       │
│  ├── Rollup 兼容钩子(7 个)             │
│  ├── Vite 独有钩子(5 个)               │
│  └── Rolldown 扩展钩子(Vite 8+)        │
└─────────────────────────────────────────┘

1.2 插件的本质

一个 Vite 插件就是一个对象,包含名字和钩子函数:

export default function myPlugin(options) {
  return
 {
    name
: 'my-plugin',         // 必须唯一
    enforce
: 'post',           // 执行顺序:pre | normal | post
    apply
: 'serve',            // 应用场景:serve | build | (默认两者)

    // Rollup 兼容钩子

    resolveId
(source, importer) { /* ... */ },
    load
(id) { /* ... */ },
    transform
(code, id) { /* ... */ },

    // Vite 独有钩子

    config
(config) { /* ... */ },
    configureServer
(server) { /* ... */ },
    handleHotUpdate
(ctx) { /* ... */ },
  }
}

2. Rollup 兼容钩子(7 个核心)

这些钩子来自 Rollup,在 Dev 和 Build 模式下都会被调用:

钩子
执行模型
调用时机
典型用途
options
Sequential
最先调用
修改 Rollup/Rolldown 配置
buildStart
Sequential
构建开始
初始化资源、建立连接
resolveId
First
解析模块路径
虚拟模块、路径别名
load
First
加载模块内容
从数据库/网络加载源码
transform
Sequential
转换模块代码
TS→JS、CSS Modules、代码注入
buildEnd
Sequential
构建结束
清理资源、报告错误
generateBundle
Sequential
产物生成
修改最终输出、添加文件

执行模型详解

First 模型(resolveId / load):

// 遍历所有插件,第一个返回非 null 结果的插件胜出
for
 (const plugin of plugins) {
  const
 result = plugin.resolveId(source, importer)
  if
 (result != null) return result  // 后续插件不再调用
}

Sequential 模型(transform):

// 所有插件依次执行,前一个的输出是后一个的输入
let
 code = originalCode
for
 (const plugin of plugins) {
  const
 result = plugin.transform(code, id)
  if
 (result) code = result.code  // 管线式串联
}

3. Vite 独有钩子(5 个)

这些钩子只在开发模式下有效(configureServer 和 handleHotUpdate)或两种模式都有(config):

3.1 config / configResolved

export default function myPlugin() {
  return
 {
    name
: 'my-plugin',
    // 修改用户配置(在配置解析前)

    config
(config) {
      return
 {
        define
: { __MY_FLAG__: JSON.stringify(true) },
        server
: { port: 3000 }
      }
    },
    // 读取最终配置(在配置解析后)

    configResolved
(resolvedConfig) {
      console
.log('最终端口:', resolvedConfig.server.port)
      // 存储供后续钩子使用

      this
.config = resolvedConfig
    }
  }
}

3.2 configureServer

export default function myPlugin() {
  return
 {
    name
: 'api-mock-plugin',
    configureServer
(server) {
      // 添加中间件(在 Vite 内置中间件之前)

      server.middlewares.use('/api', (req, res) => {
        res.end(JSON.stringify({ msg: 'mocked' }))
      })

      // 或在内部中间件之后

      return
 () => {
        server.middlewares.use('/api2', handler)
      }
    }
  }
}

3.3 transformIndexHtml

export default function myPlugin() {
  return
 {
    name
: 'html-transform-plugin',
    transformIndexHtml
(html) {
      return
 html.replace(
        '</head>'
,
        '<script>console.log("injected")</script></head>'

      )
    }
  }
}

3.4 handleHotUpdate

export default function myPlugin() {
  return
 {
    name
: 'hmr-filter-plugin',
    handleHotUpdate
({ file, server, modules, read }) {
      if
 (file.endsWith('.md')) {
        // 自定义 HMR 行为:只重新加载特定模块

        const
 mods = modules.filter(m => m.id?.includes('docs'))
        return
 mods
      }
      // 返回 undefined 表示使用默认行为

    }
  }
}

4. 插件顺序控制

4.1 enforce 排序

 ┌─ pre 钩子 ─────────────────────────┐
 │  vite:pre-alias, vite:resolve       │
 ├─ normal 钩子 ──────────────────────┤
 │  用户插件(按配置顺序)              │
 ├─ post 钩子 ────────────────────────┤
 │  vite:define, vite:css-post         │
 └─────────────────────────────────────┘

4.2 apply 过滤

// 只在开发模式生效
{ name: 'dev-only', apply: 'serve' }

// 只在构建模式生效

{ name: 'build-only', apply: 'build' }

// 条件判断

{ name: 'conditional', apply: (config, { command }) => {
  return
 command === 'build' && config.mode === 'production'
}}

5. Vite 8:Rolldown 插件兼容

Vite 8 用 Rolldown 替代了 esbuild + Rollup,但插件 API 保持兼容:

5.1 自动兼容层

// Vite 8 内部自动转换
rollupOptions.output  → rolldownOptions.output
esbuild.transform     → oxc.transform

大多数现有 Vite 插件无需修改即可在 Vite 8 中运行。

5.2 hookFilter(性能优化)

Rust/JS 通信是 Vite 8 的性能瓶颈。hookFilter 让 Rolldown 在 Rust 侧直接过滤,减少不必要的 JS 调用:

export default function myPlugin() {
  return
 {
    name
: 'optimized-plugin',
    transform
: {
      // 只对 .vue 文件调用 JS 的 transform

      filter
: { id: /\.vue$/ },
      handler
(code, id) {
        // Rust 侧已过滤,这里只会收到 .vue 文件

        return
 transformVue(code)
      }
    }
  }
}

性能影响:大型项目(10k+ 模块)中,hookFilter 可减少 60% 以上的 JS ↔ Rust 通信。

5.3 moduleType 标注

export default function myPlugin() {
  return
 {
    name
: 'my-plugin',
    transform
: {
      // 告诉 Rolldown 输出类型

      moduleType
: 'js',  // 'js' | 'css' | 'asset'
      handler
(code, id) {
        return
 { code: transpiled, map: sourcemap }
      }
    }
  }
}

6. 插件通信机制

6.1 resolvedConfig 共享

// 插件 A
configResolved
(config) {
  config.myCustomData = { theme: 'dark' }
}

// 插件 B(在 A 之后执行)

configResolved
(config) {
  console
.log(config.myCustomData.theme)  // 'dark'
}

6.2 虚拟模块

// 插件 A:提供虚拟模块
resolveId
(id) {
  if
 (id === 'virtual:config') return '\0virtual:config'
},
load
(id) {
  if
 (id === '\0virtual:config') {
    return
 `export const theme = "${this.config.theme}"`
  }
}

// 源码中直接使用

import
 { theme } from 'virtual:config'

6.3 自定义上下文

// Vite 8 的插件上下文扩展
export
 default function myPlugin() {
  return
 {
    name
: 'ctx-plugin',
    async
 transform(code, id) {
      // this.resolve — 解析模块路径

      // this.load — 加载模块

      // this.emitFile — 输出文件

      // this.addWatchFile — 添加监听

      const
 resolved = await this.resolve('./theme.css', id)
    }
  }
}

7. 钩子执行时序图

一次完整的 Dev 请求处理流程:

请求 /src/App.vue
      │
      ▼
  ┌─────────┐
  │ resolveId │ ← 依次调用所有插件的 resolveId
  └────┬─────┘   返回 /absolute/path/App.vue
       │
       ▼
  ┌─────────┐
  │   load    │ ← 依次调用,第一个返回内容的胜出
  └────┬─────┘   返回原始 SFC 代码
       │
       ▼
  ┌──────────┐
  │ transform │ ← 串行执行所有插件
  │  pre      │    vite:vue → @vitejs/plugin-vue
  │  normal   │    用户插件
  │  post     │    vite:esbuild/oxc → vite:import-analysis
  └────┬──────┘   返回编译后的 JS 代码
       │
       ▼
   HTTP 响应给浏览器

8. 插件开发 Checklist

#
检查项
说明
1
name 唯一
避免与其他插件冲突
2
enforce 正确
pre/normal/post 按需设置
3
apply 合理
只在需要的模式生效
4
hookFilter(Vite 8)
大型项目必加,减少 60%+ 通信
5
虚拟模块前缀 \0
防止其他插件处理
6
sourcemap 传递
transform 返回值包含 map
7
错误处理
try/catch 包裹异步操作
8
缓存策略
避免重复计算
9
热更新支持
实现 handleHotUpdate
10
moduleType 标注
Vite 8 Rolldown 兼容
11
ESM 输出
插件本身用 ESM 格式
12
类型声明
提供 TypeScript 类型

9. 速查卡

┌──────────────────────────────────────────────────────┐
│             Vite 插件钩子速查                         │
├──────────────┬──────────┬────────────────────────────┤
│ 钩子         │ 模型     │ 最佳用途                   │
├──────────────┼──────────┼────────────────────────────┤
│ config       │ Seq      │ 修改/合并用户配置          │
│ configResolved│ Seq     │ 读取最终配置               │
│ configureServer│ Seq    │ 添加开发服务器中间件        │
│ transformIndexHtml│ Seq │ 修改 HTML                  │
│ resolveId    │ First    │ 虚拟模块/路径映射           │
│ load         │ First    │ 自定义加载逻辑             │
│ transform    │ Seq      │ 代码转换                   │
│ handleHotUpdate│ First  │ 自定义 HMR                 │
│ buildStart   │ Seq      │ 构建初始化                 │
│ buildEnd     │ Seq      │ 构建清理                   │
│ generateBundle│ Seq     │ 修改产物                   │
└──────────────┴──────────┴────────────────────────────┘

下期预告

08 | 手把手:5 个实战插件从入门到精通 — 从 Banner 注入到 i18n 提取,5 个真实可用的插件逐行讲解,每个都带完整测试。


💡 移动APP开发 | 资讯·工具·教程·社区
📱 关注我们,获取更多移动开发技术干货
💬 加入社群,与全国开发者交流成长
❤️ 觉得有用?点个"在看"分享给更多人!

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-06-16 23:04:33 HTTP/1.1 GET : https://www.yeyulingfeng.com/a/754627.html
  2. 运行时间 : 0.264798s [ 吞吐率:3.78req/s ] 内存消耗:4,838.33kb 文件加载:145
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=1d959505f632050c232384463124394e
  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.001183s ] mysql:host=127.0.0.1;port=3306;dbname=wenku;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001718s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000771s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000683s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001290s ]
  6. SELECT * FROM `set` [ RunTime:0.000511s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001490s ]
  8. SELECT * FROM `article` WHERE `id` = 754627 LIMIT 1 [ RunTime:0.001574s ]
  9. UPDATE `article` SET `lasttime` = 1781622274 WHERE `id` = 754627 [ RunTime:0.021553s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 64 LIMIT 1 [ RunTime:0.000616s ]
  11. SELECT * FROM `article` WHERE `id` < 754627 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.001261s ]
  12. SELECT * FROM `article` WHERE `id` > 754627 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.001081s ]
  13. SELECT * FROM `article` WHERE `id` < 754627 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.003194s ]
  14. SELECT * FROM `article` WHERE `id` < 754627 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.002569s ]
  15. SELECT * FROM `article` WHERE `id` < 754627 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.018611s ]
0.271197s