当前位置:首页>python>Python pickle模块详细介绍

Python pickle模块详细介绍

  • 2026-02-06 07:10:35
Python pickle模块详细介绍

1. 创始时间与作者

  • 创始时间pickle 模块最早随 Python 1.4 版本于 1996年 发布

  • 核心开发者

    • Guido van Rossum:Python创始人,设计了pickle的基础协议

    • Jim Fulton:Zope创始人,改进并实现了pickle的扩展机制

    • Tim Peters:Python核心开发者,优化了pickle性能

    • Python核心团队:持续维护和改进

  • 项目定位Python对象序列化与反序列化标准库,用于将Python对象转换为字节流,以便存储或传输

2. 官方资源

  • Python文档地址https://docs.python.org/3/library/pickle.html

  • 源代码位置Python标准库源代码中的 Lib/pickle.py

  • PEP相关文档

    • PEP 307:Pickle增强和扩展

    • PEP 3154:Pickle协议版本4

    • PEP 574:Pickle协议5带外数据支持

  • 相关项目

    • cPickle(Python 2):C语言实现的快速pickle

    • pickle5:向后移植的pickle协议5

3. 核心功能

4. 应用场景

1. 数据持久化存储

import pickle
import os

# 定义复杂数据结构
data = {
'name''张三',
'age'30,
'skills': ['Python''机器学习''数据分析'],
'projects': {
'current''智能推荐系统',
'completed': ['电商平台''财务系统']
    }
}

# 序列化到文件
with open('user_data.pkl''wb'as f:
pickle.dump(dataf)

print(f"文件大小: {os.path.getsize('user_data.pkl')} 字节")

# 从文件反序列化
with open('user_data.pkl''rb'as f:
loaded_data = pickle.load(f)

print(f"恢复的数据: {loaded_data}")

2. 机器学习模型保存

import pickle
import numpy as np
from sklearn.ensemble import RandomForestClassifier
from sklearn.datasets import make_classification

# 生成示例数据
Xy = make_classification(n_samples=1000n_features=20random_state=42)

# 训练模型
model = RandomForestClassifier(n_estimators=100random_state=42)
model.fit(Xy)

# 保存模型
with open('model.pkl''wb'as f:
pickle.dump(modelf)

# 加载并预测
with open('model.pkl''rb'as f:
loaded_model = pickle.load(f)

# 创建新数据进行预测
new_data = np.random.randn(120)
prediction = loaded_model.predict(new_data)
print(f"预测结果: {prediction}")

3. 分布式计算任务传递

import pickle
import multiprocessing as mp

def process_task(task_data):
"""处理任务的函数"""
# 这里模拟一些处理逻辑
result = sum(task_data*2
return result

def worker(task_pickle):
"""工作进程函数"""
# 反序列化任务
task_data = pickle.loads(task_pickle)
result = process_task(task_data)
# 序列化结果
return pickle.dumps(result)

# 主进程
if __name__ == '__main__':
# 创建任务数据
tasks = [
        [12345],
        [102030],
        [100200300400]
    ]

# 创建进程池
with mp.Pool(processes=3as pool:
# 序列化任务并提交
pickled_tasks = [pickle.dumps(taskfor task in tasks]
results = pool.map(workerpickled_tasks)

# 反序列化结果
decoded_results = [pickle.loads(resultfor result in results]
print(f"处理结果: {decoded_results}")

4. 缓存计算结果

import pickle
import hashlib
import time
import os

class PickleCache:
"""基于pickle的缓存系统"""

def __init__(selfcache_dir='.cache'):
self.cache_dir = cache_dir
os.makedirs(cache_direxist_ok=True)

def _get_cache_path(selfkey):
"""获取缓存文件路径"""
# 使用MD5哈希作为文件名
key_hash = hashlib.md5(key.encode()).hexdigest()
return os.path.join(self.cache_dirf"{key_hash}.pkl")

def get(selfkeyfunc=None*args**kwargs):
"""获取缓存或计算结果"""
cache_path = self._get_cache_path(key)

# 检查缓存是否存在
if os.path.exists(cache_path):
try:
with open(cache_path'rb'as f:
print(f"从缓存加载: {key}")
return pickle.load(f)
except  (pickle.UnpicklingErrorEOFError):
print(f"缓存损坏,重新计算: {key}")

# 计算并缓存结果
if func is None:
raise ValueError("需要提供计算函数")

result = func(*args**kwargs)

# 保存到缓存
with open(cache_path'wb'as f:
pickle.dump(resultf)

print(f"计算并缓存: {key}")
return result

# 使用示例
def expensive_computation(n):
"""模拟耗时计算"""
time.sleep(2)  # 模拟耗时
return sum(range(n))

cache = PickleCache()

# 第一次计算(耗时)
start = time.time()
result1 = cache.get("sum_1000000"expensive_computation1000000)
print(f"结果1: {result1}, 耗时: {time.time() - start:.2f}秒")

# 第二次相同计算(快速从缓存加载)
start = time.time()
result2 = cache.get("sum_1000000"expensive_computation1000000)
print(f"结果2: {result2}, 耗时: {time.time() - start:.2f}秒")

5. 底层逻辑与技术原理

序列化过程架构

关键技术实现

  1. 协议设计

    • 协议0:ASCII协议,人类可读但体积大

    • 协议1:旧版二进制协议

    • 协议2:Python 2.3引入,支持新式类

    • 协议3:Python 3.0默认,处理Unicode

    • 协议4:Python 3.4引入,支持大对象

    • 协议5:Python 3.8引入,带外数据传输

  2. 对象序列化过程

    # 简化版序列化流程
    def pickle_object(obj):
    # 1. 检查对象类型
    obj_type = type(obj)

    # 2. 查找对应的序列化器
    if hasattr(obj'__reduce_ex__'):
    # 使用对象的自定义序列化方法
    return obj.__reduce_ex__(protocol)
    elif obj_type in _dispatch_table:
    # 使用注册的序列化函数
    return _dispatch_table[obj_type](obj)
    else:
    # 默认序列化逻辑
    return default_serialize(obj)
  3. 递归处理机制

    • 容器对象(list、dict、tuple)递归处理元素

    • 维护memo字典避免循环引用重复序列化

    • 使用ID追踪已序列化对象

  4. 反序列化过程

    • 字节码解释执行重建对象

    • __setstate__方法恢复对象状态

    • 安全验证和类型检查


6. 安装与配置

基础说明

pickle是Python标准库的一部分,无需单独安装

# 验证pickle模块
python -c "import pickle; print(f'pickle版本: {pickle.__version__}')"

Python版本对应关系

Python版本pickle默认协议支持协议重要特性
Python 2.3-2.7协议00,1,2支持cPickle加速
Python 3.0-3.3协议30,1,2,3默认协议3,Unicode支持
Python 3.4-3.7协议30,1,2,3,4协议4支持大对象
Python 3.8+协议40,1,2,3,4,5协议5带外数据

性能优化安装

# Python 2中可使用cPickle获得更好性能
# Python 3中pickle模块已用C实现,无需额外安装

# 安装pickle5以在旧版本中使用协议5
pip install pickle5

验证安装与版本

import pickle
import sys

print(f"Python版本: {sys.version}")
print(f"pickle模块: {pickle.__name__}")
print(f"最高支持协议: {pickle.HIGHEST_PROTOCOL}")
print(f"默认协议: {pickle.DEFAULT_PROTOCOL}")

# 测试序列化
test_obj = {"name""test""value"123}
pickled = pickle.dumps(test_obj)
print(f"序列化大小: {len(pickled)} 字节")

# 测试反序列化
unpickled = pickle.loads(pickled)
print(f"反序列化验证: {unpickled == test_obj}")

7. 性能特点与优化

协议性能对比

import pickle
import time
import sys

def benchmark_protocol(objprotocol):
"""测试不同协议的序列化性能"""
start = time.time()
data = pickle.dumps(objprotocol=protocol)
dump_time = time.time() -start

start = time.time()
pickle.loads(data)
load_time = time.time() -start

return len(data), dump_timeload_time

# 测试数据
test_data = {
'list'list(range(10000)),
'dict': {str(i): for in range(1000)},
'nested': [[[for in range(10)] for in range(10)] for in range(10)]
}

print("协议性能对比:")
print("="*60)
print(f"{'协议':<10} {'大小(字节)':<15} {'序列化时间(s)':<15} {'反序列化时间(s)':<15}")
print("-"*60)

for protocol in range(pickle.HIGHEST_PROTOCOL+1):
sizedump_tload_t = benchmark_protocol(test_dataprotocol)
print(f"{protocol:<10} {size:<15} {dump_t:<15.6f} {load_t:<15.6f}")

内存优化技巧

import pickle
import io

class OptimizedPickler:
"""优化版Pickler,减少内存使用"""

@staticmethod
def dump_to_bytes(objprotocol=None):
"""直接序列化到字节,避免中间字符串"""
file = io.BytesIO()
pickler = pickle.Pickler(fileprotocol=protocol)
# 优化:禁用备忘录以减少内存(适用于无循环引用的对象)
pickler.fast = True
pickler.dump(obj)
return file.getvalue()

@staticmethod
def dump_compressed(objprotocol=None):
"""压缩序列化数据"""
import zlib
data = pickle.dumps(objprotocol=protocol)
compressed = zlib.compress(data)
print(f"压缩率: {len(compressed)/len(data)*100:.1f}%")
return compressed

@staticmethod
def load_compressed(compressed_data):
"""加载压缩的数据"""
import zlib
data = zlib.decompress(compressed_data)
return pickle.loads(data)

# 使用示例
data = {"key""value"*1000}
optimized = OptimizedPickler()

# 普通序列化
normal = pickle.dumps(data)
print(f"普通序列化大小: {len(normal)} 字节")

# 优化序列化
optimized_bytes = optimized.dump_to_bytes(data)
print(f"优化序列化大小: {len(optimized_bytes)} 字节")

# 压缩序列化
compressed = optimized.dump_compressed(data)
print(f"压缩后大小: {len(compressed)} 字节")

8. 安全注意事项

反序列化安全风险

import pickle

# 危险的反序列化示例(不要在生产环境使用)
class MaliciousClass:
def __reduce__(self):
# 反序列化时会执行系统命令
import os
return (os.system, ('echo "恶意代码执行"',))

# 创建恶意对象
malicious = MaliciousClass()
malicious_data = pickle.dumps(malicious)

# 反序列化会执行命令(危险!)
# pickle.loads(malicious_data)  # 不要执行!

安全反序列化方案

import pickle
import builtins

class SafeUnpickler(pickle.Unpickler):
"""安全的Unpickler,限制可加载的类"""

# 白名单:只允许这些模块中的类
SAFE_MODULES = {
'__builtin__': ['list''dict''tuple''str''int''float'],
'builtins': ['list''dict''tuple''str''int''float''bool'],
'collections': ['OrderedDict''defaultdict'],
'datetime': ['datetime''date''time'],
'decimal': ['Decimal'],
'fractions': ['Fraction'],
'types': ['MappingProxyType'],
    }

def find_class(selfmodulename):
# 检查模块是否在白名单中
if module in self.SAFE_MODULES:
if name in self.SAFE_MODULES[module]:
# 安全导入
return getattr(__import__(module), name)

# 拒绝不安全的类
raise pickle.UnpicklingError(
f"禁止加载类: {module}.{name}"
        )

def safe_loads(data):
"""安全地加载pickle数据"""
import io
file = io.BytesIO(data)
return SafeUnpickler(file).load()

# 使用示例
safe_data = {'name''安全数据''value'123}
pickled = pickle.dumps(safe_data)

try:
result = safe_loads(pickled)
print(f"安全加载成功: {result}")
except pickle.UnpicklingError as e:
print(f"安全加载失败: {e}")

生产环境最佳实践

import pickle
import hmac
import hashlib

class SignedPickle:
"""签名验证的pickle序列化"""

def __init__(selfsecret_key):
self.secret_key = secret_key.encode()

def dumps(selfobj):
"""序列化并签名"""
data = pickle.dumps(obj)
signature = hmac.new(self.secret_keydatahashlib.sha256).digest()
return signature+data

def loads(selfsigned_data):
"""验证签名并反序列化"""
signature = signed_data[:32]  # SHA256签名长度
data = signed_data[32:]

# 验证签名
expected_signature = hmac.new(
self.secret_keydatahashlib.sha256
        ).digest()

if not hmac.compare_digest(signatureexpected_signature):
raise ValueError("签名验证失败")

return pickle.loads(data)

# 使用示例
secret = "my-secret-key"
sp = SignedPickle(secret)

data = {"user""alice""balance"1000}
signed = sp.dumps(data)
print(f"签名数据长度: {len(signed)}")

# 验证并加载
loaded = sp.loads(signed)
print(f"加载的数据: {loaded}")

# 尝试篡改数据
tampered = signed[:-10+b'xxx'+signed[-7:]
try:
sp.loads(tampered)
except ValueError as e:
print(f"篡改检测: {e}")

9. 高级功能与技巧

自定义序列化

import pickle

class CustomObject:
"""支持自定义序列化的对象"""

def __init__(selfnamedata):
self.name = name
self.data = data
self._cache = {}  # 不序列化的属性

def __getstate__(self):
"""控制序列化的状态"""
state = self.__dict__.copy()
# 删除不需要序列化的属性
del state['_cache']
# 可以添加额外信息
state['_version'] = '1.0'
return state

def __setstate__(selfstate):
"""控制反序列化的状态"""
version = state.pop('_version''1.0')
self.__dict__.update(state)
# 恢复默认值
self._cache = {}
# 版本迁移逻辑
if version == '1.0':
self._migrate_from_v1()

def _migrate_from_v1(self):
"""从版本1迁移数据"""
if hasattr(self'old_field'):
self.data = self.old_field*2
delattr(self'old_field')

def __reduce__(self):
"""更底层的序列化控制"""
# 返回 (构造函数, 参数, 状态)
return (
self.__class__,  # 可调用对象
            (self.nameself.data),  # 参数
self.__getstate__()  # 状态
        )

# 测试自定义序列化
obj = CustomObject("测试对象", [123])
obj._cache['temp'] = '不保存的数据'

# 序列化
data = pickle.dumps(obj)
print(f"序列化大小: {len(data)} 字节")

# 反序列化
new_obj = pickle.loads(data)
print(f"恢复的对象: {new_obj.name}")
print(f"数据: {new_obj.data}")
print(f"缓存是否恢复: {hasattr(new_obj, '_cache')}")

协议5带外数据

import pickle

# 协议5支持带外数据传输,适合大数据处理
def use_protocol5():
"""使用协议5的带外数据功能"""
import numpy as np

# 创建大数据
large_array = np.random.randn(1000010000)  # 800MB数据

# 使用协议5序列化
buffers = []
data = pickle.dumps(
        {
'metadata': {'shape'large_array.shape'dtype'str(large_array.dtype)},
'array'large_array
        },
protocol=5,
buffer_callback=buffers.append# 缓冲区回调
    )

print(f"元数据大小: {len(data)} 字节")
print(f"缓冲区数量: {len(buffers)}")
print(f"第一个缓冲区大小: {buffers[0].nbytes if buffers else 0} 字节")

# 可以分别传输元数据和缓冲区
return databuffers

# 注意:协议5需要Python 3.8+
if pickle.HIGHEST_PROTOCOL>5:
print("支持协议5")
# use_protocol5()  # 需要大量内存,谨慎运行
else:
print("不支持协议5")

10. 替代方案与比较

序列化方案对比

特性picklejsonmsgpackprotobufyaml
Python对象支持⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
跨语言支持⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
性能⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
数据大小⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
可读性⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
安全性⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐
模式演进⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐⭐

pickle适用场景总结

使用pickle的场景

  1. Python内部数据交换

  2. 机器学习模型持久化

  3. 临时缓存存储

  4. 进程间通信(相同Python版本)

  5. 复杂对象图的保存

避免使用pickle的场景

  1. 跨语言数据交换

  2. 不可信数据源的反序列化

  3. 长期数据存储(格式可能变化)

  4. 需要人类可读的数据存储

  5. 需要严格模式演进的数据


11. 企业级应用案例

1. 机器学习平台

  • Scikit-learn:模型持久化标准格式

  • TensorFlow:Keras模型保存(h5格式内部使用pickle)

  • PyTorchtorch.save()默认使用pickle

2. 分布式计算框架

  • Celery:任务序列化传递

  • Dask:分布式任务调度

  • Ray:Actor和任务序列化

3. Web框架

  • Django:会话数据存储

  • Flask:缓存后端支持

  • FastAPI:依赖项缓存

4. 数据分析平台

  • Pandas:DataFrame序列化选项

  • Jupyter:Notebook内核通信

  • Apache Airflow:任务状态序列化


总结

pickle是Python生态中不可或缺的对象序列化工具,核心价值在于:

  1. 原生Python支持:无需第三方库,开箱即用

  2. 完整对象序列化:支持几乎所有Python对象类型

  3. 协议演进:6个协议版本适应不同需求

  4. 生态系统集成:广泛用于机器学习、Web开发、科学计算

技术特色

  • 递归对象图序列化

  • 循环引用处理

  • 自定义序列化控制

  • 协议版本向后兼容

安全警告

  • 永远不要反序列化不受信任的数据

  • 使用白名单机制限制可加载的类

  • 考虑使用签名验证数据完整性

最佳实践

  • 生产环境使用最高协议版本

  • 大对象使用协议5带外数据传输

  • 长期存储数据考虑兼容性问题

  • 跨Python版本使用注意协议差异

替代方案建议

  • 跨语言:JSON、Protocol Buffers、MessagePack

  • 高性能:PyArrow、Parquet

  • 可读性:YAML、TOML

  • 安全性:JSON with schema validation

学习资源

  • 官方文档:https://docs.python.org/3/library/pickle.html

  • Python源码:Lib/pickle.py(优秀的学习材料)

  • 《Python Cookbook》第5章:文件与IO

pickle作为Python标准库的一部分,其代码质量、文档完整性和社区支持都是最高水平的。虽然存在安全风险,但在正确的使用场景下,它是Python开发者最强大的工具之一。

最新文章

随机文章

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