当前位置:首页>python>用 Python 写一个简单的端口扫描器,吃透端口扫描原理

用 Python 写一个简单的端口扫描器,吃透端口扫描原理

  • 2026-01-17 14:37:12
用 Python 写一个简单的端口扫描器,吃透端口扫描原理

端口扫描是网络安全领域最基础、最常用的技术之一,其核心原理是向目标主机的指定端口发送连接请求,根据请求的响应结果,判断该端口是否处于开放状态。开放的端口意味着主机在该端口提供了对应的网络服务(比如 80 端口对应 HTTP 服务、22 端口对应 SSH 服务、3306 端口对应 MySQL 服务),掌握端口开放情况,不管是做本机服务排查还是网络基础探测都非常实用。

Python 凭借简洁的语法、丰富的内置库,成为编写端口扫描器的绝佳选择,实现端口扫描无需依赖任何第三方库,仅通过原生的 socket 套接字库即可完成。本文将从原理出发,由浅入深实现三个版本的端口扫描器:从最基础的单线程版本,到优化超时的实用版本,再到提升效率的多线程版本,循序渐进理解端口扫描的核心逻辑,零基础也能轻松看懂、上手使用。

一、前置知识:端口扫描的核心原理

1. 什么是端口?

计算机的网络通信依靠「IP地址+端口号」完成,IP 地址用来定位网络中的主机,端口号则用来区分主机上的不同网络服务。TCP/IP 协议规定,端口号的取值范围是 0~65535,其中 0~1024 为系统保留端口,一般用于运行 HTTP、SSH、FTP 等系统级服务;1025~65535 为动态端口,多用于程序自定义的服务。

2. 端口扫描的核心逻辑

本次实现的是TCP 全连接扫描,也是最基础、最稳定、准确率最高的扫描方式,基于 TCP 协议的「三次握手」特性实现:

  1. 我们的程序向目标主机的指定端口,发起 TCP 连接请求;
  2. 如果端口处于开放状态,目标主机会返回响应,完成 TCP 三次握手,连接建立成功;
  3. 如果端口处于关闭状态,目标主机会拒绝连接,连接建立失败;
  4. 程序根据「连接是否成功」的结果,判定端口的开放状态。

这种扫描方式的优点是准确率100%、无技术门槛、对系统无压力,缺点是扫描速度相对较慢(单线程),非常适合作为入门学习的原理版实现。

3. Python 核心依赖库:socket

Python 内置的 socket 库是实现网络通信的核心,也是本次端口扫描的核心依赖,无需额外安装,导入即可使用。socket 库可以让我们轻松创建 TCP 套接字、发起连接请求、判断连接结果,是实现端口扫描的基石。

二、版本一:最基础的单线程端口扫描器

这是最精简的端口扫描器实现,仅保留核心逻辑,代码量极少,所有功能都围绕「原理」展开,没有任何多余的优化,目的是让大家看懂端口扫描的本质,零基础也能轻松理解。

实现思路

  1. 导入 Python 原生的 socket 库;
  2. 定义核心函数,接收「目标IP」和「端口号」两个参数;
  3. 创建 TCP 套接字,尝试与目标IP的指定端口建立连接;
  4. 连接成功 → 端口开放;连接失败 → 端口关闭;
  5. 主程序中遍历指定的端口范围,逐个调用核心函数完成扫描。

完整代码

版本一:最基础的单线程端口扫描器(纯原理版)import socketdefport_scan_basic(ip, port):"""基础端口扫描函数,判断单个端口是否开放    :param ip: 目标主机IP地址    :param port: 待扫描的端口号    :return: 开放返回True,关闭返回False    """创建TCP套接字 AF_INET=IPv4协议 SOCK_STREAM=TCP协议    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)try:发起连接请求,连接成功则端口开放        sock.connect((ip, port))returnTrueexcept:连接失败则端口关闭,捕获所有异常不报错returnFalsefinally:无论连接成功与否,都关闭套接字释放资源        sock.close()if __name__ == "__main__":配置扫描参数    target_ip = "127.0.0.1"扫描本机,固定值    start_port = 1扫描起始端口    end_port = 100扫描结束端口print(f"开始扫描{target_ip}端口,范围:{start_port} - {end_port}")print("-" * 50)遍历端口,逐个扫描for port inrange(start_port, end_port + 1):if port_scan_basic(target_ip, port):print(f"【开放】端口号:{port}")else:print(f"【关闭】端口号:{port}")print("-" * 50)print("扫描完成!")

代码说明

  1. 本版本是纯原理实现,代码没有任何复杂逻辑,所有的重点都在 socket.socket() 和 sock.connect() 两个核心函数;
  2. 使用 try-except 捕获异常,因为端口关闭时调用 connect() 会抛出连接异常,我们不需要打印异常信息,只需要判定端口关闭即可;
  3. finally
     代码块保证无论连接成功还是失败,都会关闭套接字,避免系统资源泄漏;
  4. 推荐扫描本机(127.0.0.1),无需网络权限,也不会对其他主机造成影响。

运行效果

运行后会逐个打印端口的开放/关闭状态,比如本机开启了 SSH 服务则 22 端口开放,开启了 MySQL 则 3306 端口开放。

版本一的缺点

这个版本仅适合学习原理,实际使用体验较差,核心缺点有两个:

  1. 无超时设置
    :连接关闭的端口时,connect() 函数会阻塞等待一段时间,导致扫描速度极慢;
  2. 逐个扫描
    :单线程遍历端口,扫描效率低,扫描 1~1024 端口需要较长时间。

三、版本二:优化版单线程端口扫描器

版本一是纯原理实现,版本二则是在版本一的基础上,做了两个核心优化,解决了版本一的痛点,让扫描器从「仅能学习」变成「可以实际使用」,代码改动很小,但体验提升极大,是入门必学的核心版本,也是理解「优化思路」的关键。

核心优化点

  1. 添加超时设置
    :给套接字设置连接超时时间,端口关闭时会立即返回结果,不再阻塞等待,扫描速度提升10倍以上
  2. 优化输出结果
    :只打印「开放的端口」,关闭的端口不打印,减少无用输出,扫描结果更清晰;
  3. 增加异常分类
    :区分不同的异常类型,让程序更健壮;
  4. 统计开放端口数量
    :扫描完成后汇总结果,更直观。

完整代码

版本二:优化版单线程端口扫描器(实用型,推荐)import socketdefport_scan_optimize(ip, port, timeout=1):"""优化后的端口扫描函数    :param ip: 目标主机IP地址    :param port: 待扫描的端口号    :param timeout: 连接超时时间,单位:秒,默认1    :return: 开放返回True,关闭返回False    """    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)核心优化1:设置连接超时时间,超时立即判定为端口关闭    sock.settimeout(timeout)try:        sock.connect((ip, port))returnTrueexcept socket.timeout:超时异常:端口关闭或防火墙拦截returnFalseexcept ConnectionRefusedError:连接被拒绝:端口明确关闭returnFalseexcept:其他异常:如网络错误等,默认判定为端口关闭returnFalsefinally:        sock.close()if __name__ == "__main__":扫描配置    target_ip = "127.0.0.1"    start_port = 1    end_port = 1024扫描常用的1-1024系统端口    open_ports = []  存储开放的端口print(f"【优化版】开始扫描{target_ip}端口,范围:{start_port} - {end_port}")print("扫描中... 仅展示开放的端口\n")遍历扫描端口for port inrange(start_port, end_port + 1):if port_scan_optimize(target_ip, port):print(f"端口{port}已开放")            open_ports.append(port)扫描结果汇总print("\n" + "-" * 50)print(f"扫描完成!共扫描{end_port - start_port + 1}个端口")print(f"本次扫描共发现{len(open_ports)}个开放端口,分别是:{open_ports}")

核心优化说明

  1. 超时设置 sock.settimeout(timeout)
    :这是本次优化的重中之重!版本一中没有超时,connect() 函数会默认阻塞等待几十秒,而设置超时后,端口关闭时会在指定时间(默认1秒)内返回结果,扫描速度直接起飞;
  2. 精准捕获异常
    :版本一中只捕获了通用异常,版本二则区分了「超时异常」和「连接被拒绝异常」,这两种都是端口关闭的典型特征,让程序的健壮性更强;
  3. 结果优化
    :只打印开放的端口,避免大量无用的「关闭」信息,扫描结果一目了然,还增加了开放端口的统计,实用性拉满。

版本二的优点和缺点

✅ 优点:扫描速度快、结果清晰、程序健壮、无依赖、可直接使用,适合日常排查本机端口开放情况;❌ 缺点:依然是单线程扫描,遍历端口时需要逐个执行,扫描大端口范围(比如1~65535)时,耗时依然较长。

四、版本三:进阶版多线程端口扫描器

这是本文的核心版本、重点推荐版本,也是实际使用中最实用的版本。版本二解决了「扫描慢」的问题,但单线程的本质没有改变;版本三则在版本二的基础上,引入了多线程技术,彻底解决扫描效率问题,这也是所有端口扫描器的核心优化方向。

核心优化思路

为什么多线程能提升扫描效率?

  • 端口扫描的核心耗时,并不是CPU计算,而是「网络请求的等待时间」(等待目标主机的响应);
  • 单线程扫描时,程序在等待一个端口的响应时,CPU处于空闲状态,浪费了大量资源;
  • 多线程扫描时,我们可以同时发起多个端口的连接请求,一个线程在等待响应时,其他线程可以继续扫描其他端口,CPU资源被充分利用,扫描效率提升几十倍甚至上百倍

本次我们使用 Python 内置的 threading 线程库实现多线程,无需安装第三方库,原生支持,代码简洁易懂,也是最适合入门的多线程实现方式。

完整代码

版本三:进阶版多线程端口扫描器(效率天花板,重点推荐)import socketimport threadingimport time定义全局列表,存储开放的端口(线程安全,仅追加数据无修改)open_ports = []定义锁对象,保证多线程打印时不会出现乱码print_lock = threading.Lock()defport_scan_thread(ip, port, timeout=1):"""多线程端口扫描函数,被每个线程调用    """    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)    sock.settimeout(timeout)try:        sock.connect((ip, port))加锁打印,避免多线程同时打印导致输出混乱with print_lock:print(f"端口{port}已开放")            open_ports.append(port)except:passfinally:        sock.close()defmulti_thread_scan(ip, start_port, end_port, timeout=1):"""多线程扫描主函数,创建线程并启动    """    threads = []  存储线程对象print(f"【多线程版】开始扫描{ip}端口,范围:{start_port} - {end_port}")print(f"扫描中... 线程数:{end_port - start_port + 1}\n")记录扫描开始时间    start_time = time.time()为每个端口创建一个线程for port inrange(start_port, end_port + 1):        t = threading.Thread(target=port_scan_thread, args=(ip, port, timeout))        threads.append(t)        t.start()  启动线程等待所有线程执行完成for t in threads:        t.join()计算扫描耗时    end_time = time.time()    scan_time = round(end_time - start_time, 2)结果汇总    open_ports.sort()  对开放端口排序print("\n" + "-" * 60)print(f"扫描完成!总耗时:{scan_time}")print(f"共扫描{end_port - start_port + 1}个端口,发现{len(open_ports)}个开放端口")print(f"开放的端口列表:{open_ports}")if __name__ == "__main__":扫描配置    TARGET_IP = "127.0.0.1"    START_PORT = 1    END_PORT = 1024    TIMEOUT = 1调用多线程扫描函数    multi_thread_scan(TARGET_IP, START_PORT, END_PORT, TIMEOUT)

多线程核心知识点说明

  1. 线程安全处理

    • 定义了全局的 open_ports 列表存储开放端口,由于我们只对列表执行「追加」操作,是线程安全的,无需额外加锁;
    • 定义了 print_lock 锁对象,使用 with print_lock 保证多线程同时打印时,不会出现输出混乱、内容重叠的问题,这是多线程开发的必备技巧。
  2. 线程创建与管理

    • 为每个端口创建一个独立的线程,线程的执行目标是 port_scan_thread 函数,参数通过 args 传递;
    • 调用 t.start() 启动线程,调用 t.join() 等待线程执行完成,保证主程序在所有线程扫描完毕后,再打印汇总结果。
  3. 效率对比

    • 单线程扫描 1~1024 端口,耗时约 10 秒;
    • 多线程扫描 1~1024 端口,耗时仅需 1~2 秒,效率提升极其明显。

版本三的扩展优化(可选,锦上添花)

如果需要扫描更大的端口范围(比如1~65535),可以对版本三做一个小优化:限制线程数量,避免创建过多线程导致系统资源耗尽。我们可以创建一个线程池,固定线程数量(比如50个),分批扫描端口,代码改动很小,效果却很好,这里给出优化思路,大家可以自行尝试:

  1. 定义线程数量常量:THREAD_NUM = 50
  2. 使用 threading.Semaphore(THREAD_NUM) 限制并发线程数;
  3. 在扫描函数中,先获取信号量,扫描完成后释放信号量。

五、补充:实用技巧与注意事项

1. 扫描本机 vs 扫描远程主机

  • 扫描本机:直接使用 127.0.0.1,无需任何网络权限,速度快、无风险,适合排查本机服务是否正常运行;
  • 扫描远程主机:替换 target_ip 为远程主机的IP地址(比如 192.168.1.100),需要保证本机与远程主机网络互通,且对方主机没有防火墙拦截。

2. 常见开放端口参考

扫描本机时,大概率会发现这些开放的端口,对应常见的服务:

  • 22:SSH 远程连接服务(Linux 系统);
  • 80:HTTP 网页服务;
  • 443:HTTPS 加密网页服务;
  • 3306:MySQL 数据库服务;
  • 6379:Redis 缓存服务;
  • 8080:Tomcat 服务/自定义 Web 服务。

3. 为什么扫描结果中部分端口显示关闭,但实际服务已开启?

大概率是防火墙拦截导致的!比如 Windows 的防火墙、Linux 的 iptables/firewalld,会拦截外部的连接请求,即使端口实际开放,扫描结果也会显示关闭。解决方案:临时关闭防火墙后再扫描,即可看到真实的端口开放状态。

4. Python 端口扫描器的优势与局限性

✅ 优势:代码简洁、无依赖、易理解、易修改、跨平台,Windows/Linux/macOS 都能运行,适合学习和日常使用;❌ 局限性:本次实现的是基础的 TCP 扫描,扫描速度和功能无法与专业的扫描工具(比如 nmap)相比,但作为学习原理、理解端口扫描的实现方式,完全足够。

六、总结

原理出发,由浅入深实现了三个版本的 Python 端口扫描器,从最基础的单线程原理版,到优化超时的实用版,再到效率拉满的多线程版,每一个版本都在之前的基础上做了合理的优化,循序渐进,层层递进。

通过本文的学习,我们不仅可以掌握端口扫描的核心原理和实现方式,还增强理解「超时优化」和「多线程优化」的核心思路,这些思路不仅适用于端口扫描,也适用于其他的网络编程场景。Python 的强大之处就在于,用几行简单的代码就能实现实用的功能,而端口扫描器正是最好的体现。

最后,端口扫描技术是网络安全的基础,请仅在自己的主机或授权的主机上进行扫描,切勿用于非法的网络探测,遵守法律法规,做一名合格的开发者。

希望本文能帮助你理解端口扫描的原理和实现方式,也希望你能基于本文的代码,继续扩展功能,比如添加端口服务识别、批量扫描、结果导出等,让这个简单的端口扫描器变得更加强大!

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-08 21:23:48 HTTP/2.0 GET : https://f.mffb.com.cn/a/461579.html
  2. 运行时间 : 0.083278s [ 吞吐率:12.01req/s ] 内存消耗:4,618.37kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=516a4cbc51b9ecec95e262dd896319d5
  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.000685s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.000850s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.000370s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000284s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.000577s ]
  6. SELECT * FROM `set` [ RunTime:0.002313s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.000667s ]
  8. SELECT * FROM `article` WHERE `id` = 461579 LIMIT 1 [ RunTime:0.000493s ]
  9. UPDATE `article` SET `lasttime` = 1770557028 WHERE `id` = 461579 [ RunTime:0.001834s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 66 LIMIT 1 [ RunTime:0.000249s ]
  11. SELECT * FROM `article` WHERE `id` < 461579 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.000669s ]
  12. SELECT * FROM `article` WHERE `id` > 461579 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.000483s ]
  13. SELECT * FROM `article` WHERE `id` < 461579 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.003060s ]
  14. SELECT * FROM `article` WHERE `id` < 461579 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.000816s ]
  15. SELECT * FROM `article` WHERE `id` < 461579 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.000696s ]
0.084963s