当前位置:首页>php>PHP 原生开发留言板:不用框架,300 行代码搞定数据存储与展示

PHP 原生开发留言板:不用框架,300 行代码搞定数据存储与展示

  • 2026-02-06 21:16:32
PHP 原生开发留言板:不用框架,300 行代码搞定数据存储与展示
      做站长这些年,经常有刚入门的朋友问我:“想学 PHP,但框架太复杂,有没有简单的实战项目练手?” 其实新手入门最好的方式,就是从最基础的原生开发做起 —— 不用花里胡哨的框架,只用 PHP+MySQL + 原生 HTML/CSS,从零写一个留言板。

      我当年学 PHP 的第一个实战项目就是留言板,前后也就写了 300 多行代码,却把 PHP 连接数据库、数据增删改查、前端交互这些核心知识点都摸透了。今天就把这个 “新手友好型” 项目的完整思路和代码分享出来,纯原生开发,新手跟着做,半小时就能跑通。

一、先理清需求:一个极简留言板要实现什么?

新手做项目别贪多,先把核心功能落地:

  1. 1、前端展示留言列表(昵称、留言内容、发布时间);
  2. 2、提供留言提交表单(昵称、留言内容输入框);
  3. 3、后端接收表单数据,验证后存入 MySQL;
  4. 4、从数据库读取留言,渲染到前端页面;
  5. 5、最基础的防错处理(比如内容为空、昵称过长)。

不用做删除、修改功能,也不用搞复杂样式,先把 “提交 - 存储 - 展示” 这个核心流程跑通,这才是关键。

二、准备工作:环境与数据库

      我用的是本地 WAMP 环境(Windows+Apache+MySQL+PHP),新手直接装个集成环境就行,不用单独配置。先建数据库和表,这步别偷懒:

1. 创建数据库和数据表

      打开 phpMyAdmin,新建数据库(比如叫msg_board),然后执行下面的 SQL 创建留言表:

CREATE TABLE `message` (  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '留言ID',  `username` varchar(20) NOT NULL COMMENT '留言人昵称',  `content` text NOT NULL COMMENT '留言内容',  `create_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '发布时间',  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='留言板数据表';

      字段不用多,id 自增做主键,username 限制长度避免乱输入,create_time 自动记录时间,足够用了。

2. 数据库连接文件

      新建conn.php,专门处理数据库连接,后续所有页面都引入这个文件,避免重复写连接代码:

<?php// 数据库配置$host 'localhost'// 本地环境默认localhost$user 'root'// 数据库用户名,默认root$pwd '你的数据库密码'// 记得改成自己的密码$dbname 'msg_board'// 刚才创建的数据库名// 连接数据库$conn mysqli_connect($host$user$pwd$dbname);if(!$conn) {    die('数据库连接失败:' . mysqli_connect_error());}// 设置字符集,避免中文乱码mysqli_set_charset($conn'utf8mb4');?>

      这里提醒新手:一定要加mysqli_set_charset,当年我第一次做的时候没加,留言全是乱码,排查了半天才找到原因。

三、核心代码:300 行实现完整功能

      整个项目就两个核心文件:index.php(展示留言 + 提交表单)、add_msg.php(处理留言提交),加起来也就 300 行代码,逐行讲清楚。

1. 主页面 index.php(展示 + 提交)

      这个文件既要展示已有的留言,又要显示提交表单,逻辑很简单:先从数据库查留言,再渲染到页面,最后写表单提交区域。

<?php// 引入数据库连接文件require_once 'conn.php';// 查询留言,按发布时间倒序(最新的在最上面)$sql = "SELECT * FROM message ORDER BY create_time DESC";$result = mysqli_query($conn, $sql);// 初始化留言数组$messages = [];if (mysqli_num_rows($result) > 0) {    while ($row = mysqli_fetch_assoc($result)) {        $messages[] = $row;    }}// 关闭查询结果mysqli_free_result($result);?><!DOCTYPE html><htmllang="zh-CN"><head>    <metacharset="UTF-8">    <title>极简留言板 | 原生PHP开发</title>    <style>        /* 简单样式,不用复杂,能看就行 */        * {            margin0;            padding0;            box-sizing: border-box;            font-family"微软雅黑", sans-serif;        }        .container {            width800px;            margin50px auto;        }        h1 {            text-align: center;            margin-bottom30px;            color#333;        }        .msg-form {            border1px solid #eee;            padding20px;            margin-bottom30px;            border-radius5px;        }        .msg-form input.msg-form textarea {            width100%;            padding10px;            margin-bottom15px;            border1px solid #ddd;            border-radius3px;        }        .msg-form textarea {            height100px;            resize: none;        }        .msg-form button {            background#0088cc;            color#fff;            border: none;            padding10px 20px;            border-radius3px;            cursor: pointer;        }        .msg-form button:hover {            background#006699;        }        .msg-list .msg-item {            border1px solid #eee;            padding15px;            margin-bottom10px;            border-radius5px;        }        .msg-item .username {            font-weight: bold;            color#0088cc;            margin-bottom10px;        }        .msg-item .content {            line-height1.6;            color#666;            margin-bottom10px;        }        .msg-item .time {            font-size12px;            color#999;            text-align: right;        }        .error {            color: red;            margin-bottom15px;            text-align: center;        }    </style></head><body>    <divclass="container">        <h1>极简留言板</h1>        <!-- 留言提交表单 -->        <divclass="msg-form">            <?php            // 接收提交后的提示信息            if (isset($_GET['msg'])) {                echo '<div class="error">' . htmlspecialchars($_GET['msg']) . '</div>';            }            ?>            <formaction="add_msg.php"method="post">                <inputtype="text"name="username"placeholder="请输入你的昵称(最多20个字)"maxlength="20">                <textareaname="content"placeholder="请输入留言内容"></textarea>                <buttontype="submit">提交留言</button>            </form>        </div>        <!-- 留言列表 -->        <divclass="msg-list">            <?php if (empty($messages)): ?>                <pstyle="text-align:center; color:#999;">暂无留言,快来抢沙发吧~</p>            <?php else: ?>                <?php foreach ($messages as $msg): ?>                    <divclass="msg-item">                        <divclass="username"><?php echo htmlspecialchars($msg['username']); ?></div>                        <divclass="content"><?php echo htmlspecialchars($msg['content']); ?></div>                        <divclass="time"><?php echo $msg['create_time']; ?></div>                    </div>                <?php endforeach; ?>            <?php endif; ?>        </div>    </div></body></html><?php// 关闭数据库连接mysqli_close($conn);?>

这里有几个新手必注意的点:

  • ● 用htmlspecialchars()转义输出内容,防止 XSS 攻击(当年我没加这个,被朋友测试时插了恶意代码,页面直接乱了);
  • ● 查询结果用完要mysqli_free_result,连接用完要mysqli_close,养成良好习惯;
  • ● 表单提交用post方法,比get安全,也能传更多内容。

2. 处理提交 add_msg.php

这个文件专门接收表单提交的数据,验证、入库,然后跳回主页面。

<?php// 引入数据库连接require_once 'conn.php';// 判断是否是POST提交if($_SERVER['REQUEST_METHOD'] !== 'POST') {    header('Location: index.php?msg=请通过表单提交留言');    exit;}// 接收并过滤数据$username trim($_POST['username'] ?? '');$content trim($_POST['content'] ?? '');// 数据验证if(empty($username)) {    header('Location: index.php?msg=昵称不能为空');    exit;}if(empty($content)) {    header('Location: index.php?msg=留言内容不能为空');    exit;}if(mb_strlen($username) > 20) {    header('Location: index.php?msg=昵称不能超过20个字');    exit;}// 预处理SQL,防止SQL注入(重点!)$stmt mysqli_prepare($conn"INSERT INTO message (username, content) VALUES (?, ?)");mysqli_stmt_bind_param($stmt'ss'$username$content);// 执行入库if(mysqli_stmt_execute($stmt)) {    // 提交成功,跳回首页    header('Location: index.php?msg=留言提交成功~');else {    // 提交失败,提示错误    header('Location: index.php?msg=留言提交失败:' . mysqli_error($conn));}// 关闭预处理语句和连接mysqli_stmt_close($stmt);mysqli_close($conn);?>

      这里最关键的是预处理语句mysqli_prepare),新手千万别直接拼接 SQL(比如INSERT INTO message VALUES ('$username', '$content')),很容易被 SQL 注入。当年我第一次写的时候用了拼接,结果被朋友用' OR 1=1 #试了一下,差点把数据库表清空,现在想起来还后怕。

四、跑起来!新手常见问题排查

      把这三个文件(conn.phpindex.phpadd_msg.php)放到 WAMP 的 www 目录下,访问localhost/index.php就能看到效果。新手大概率会遇到这几个问题,提前说下怎么解决:

  1. 1、数据库连接失败
    :检查conn.php里的密码是否正确,MySQL 服务是否启动;
  2. 2、中文乱码
    :确认数据库、表、PHP 页面的字符集都是utf8mb4(支持 emoji);
  3. 3、提交留言没反应
    :检查表单的action是否指向add_msg.php,PHP 是否开启了错误提示;
  4. 4、SQL 注入测试
:可以试试在昵称框输入' or 1=1 #,如果用了预处理,会直接把这个当成普通字符串,不会触发注入。

五、最后说两句:原生开发的意义

      可能有人会说:“现在都用框架了,写原生代码没用?” 但我始终觉得,新手先吃透原生 PHP 的核心逻辑 —— 怎么连数据库、怎么处理表单、怎么防漏洞,比直接套框架更重要。

      这个 300 行的留言板,虽然简单,但包含了 PHP 开发的核心知识点:数据库操作、表单处理、数据验证、安全防护、前后端交互。把这个项目吃透,再去学 ThinkPHP、Laravel 这些框架,你会发现框架只是把这些原生逻辑封装得更易用,底层原理都是相通的。

      大家可以直接复制粘贴跑起来,也可以自己加功能 —— 比如加个留言删除、用户头像、验证码,一步步改造,慢慢就有编程思维了。

      新手学 PHP,别贪快,从这种小项目开始,稳扎稳打,比看一百篇理论文章都管用。如果大家在做的过程中遇到问题,欢迎在留言区交流,我看到都会回复~

END

点分享

点收藏

点点赞

点在看

最新文章

随机文章

基本 文件 流程 错误 SQL 调试
  1. 请求信息 : 2026-02-07 10:49:07 HTTP/2.0 GET : https://f.mffb.com.cn/a/470399.html
  2. 运行时间 : 0.179549s [ 吞吐率:5.57req/s ] 内存消耗:4,585.74kb 文件加载:140
  3. 缓存信息 : 0 reads,0 writes
  4. 会话信息 : SESSION_ID=e8050a0b275727124b11926961e9bf76
  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.000710s ] mysql:host=127.0.0.1;port=3306;dbname=f_mffb;charset=utf8mb4
  2. SHOW FULL COLUMNS FROM `fenlei` [ RunTime:0.001413s ]
  3. SELECT * FROM `fenlei` WHERE `fid` = 0 [ RunTime:0.011514s ]
  4. SELECT * FROM `fenlei` WHERE `fid` = 63 [ RunTime:0.000639s ]
  5. SHOW FULL COLUMNS FROM `set` [ RunTime:0.001531s ]
  6. SELECT * FROM `set` [ RunTime:0.000751s ]
  7. SHOW FULL COLUMNS FROM `article` [ RunTime:0.001565s ]
  8. SELECT * FROM `article` WHERE `id` = 470399 LIMIT 1 [ RunTime:0.001174s ]
  9. UPDATE `article` SET `lasttime` = 1770432547 WHERE `id` = 470399 [ RunTime:0.011890s ]
  10. SELECT * FROM `fenlei` WHERE `id` = 64 LIMIT 1 [ RunTime:0.002646s ]
  11. SELECT * FROM `article` WHERE `id` < 470399 ORDER BY `id` DESC LIMIT 1 [ RunTime:0.001192s ]
  12. SELECT * FROM `article` WHERE `id` > 470399 ORDER BY `id` ASC LIMIT 1 [ RunTime:0.002934s ]
  13. SELECT * FROM `article` WHERE `id` < 470399 ORDER BY `id` DESC LIMIT 10 [ RunTime:0.007533s ]
  14. SELECT * FROM `article` WHERE `id` < 470399 ORDER BY `id` DESC LIMIT 10,10 [ RunTime:0.026876s ]
  15. SELECT * FROM `article` WHERE `id` < 470399 ORDER BY `id` DESC LIMIT 20,10 [ RunTime:0.006956s ]
0.183431s