TP5.0的“请求缓存”,把页面缓存为静态HTML文件,提升加载速度

TP5.0的"请求缓存"不仅仅是告诉浏览器缓存页面,它其实做了两件事

它既在服务器本地缓存了页面数据
又指挥浏览器进行缓存。

我们可以把它理解为一个"双重缓存"机制。

为了让你更好地理解,我们来看一个实际例子。假设你有一个博客文章详情页 http://tp5.com/blog/1。

1、第一次访问(缓存建立):

用户请求到达服务器,TP5发现没有这个请求的缓存。

框架正常执行PHP代码,从数据库查询ID为1的文章。

TP5将生成的最终HTML页面保存到服务器的本地缓存中(比如runtime/cache/目录下),同时在HTTP响应头中设置了缓存指令(如Cache-Control和Last-Modified),告诉浏览器:"这个页面你可以缓存起来,有效期是10分钟。"

最终,浏览器收到完整的页面(状态码200),并将其缓存到本地。

2、10分钟内第二次访问(缓存生效):

浏览器带着本地缓存的标识(If-Modified-Since头)再次请求同一个地址。

TP5的请求缓存机制首先被触发。它会检查:

服务器本地缓存:发现已经存有blog/1这个页面的完整内容。

浏览器缓存:通过分析请求头,发现浏览器自己也有这个页面的缓存,并且还没有过期(10分钟内)。

于是,TP5什么PHP代码都不执行,直接向浏览器返回一个304 Not Modified状态码。这个状态码就像在告诉浏览器:"你本地存的页面还是最新的,直接用吧!"

浏览器收到304后,立刻从自己的本地缓存里加载页面。整个过程几乎没有网络传输,速度极快。

新的浏览器请求的时候,服务器就直接返回静态HTML文件了,速度也很快

tp5.0 配置缓存 admin 模块下的 admin/login/index 这个页面

application ->route.php 在这个application 文件夹下的route.php的配置文件里,添加如下代码

分组的方式

php 复制代码
Route::group('admin', function() {
    //登陆页缓存 3600 秒  60*60*100 =360000  100小时=4.1天
    Route::get('login/index', 'admin/login/index',['cache' => 0]); //  ,['cache' => 360000]     0 表示永久缓存
});

或者直接不分组

php 复制代码
Route::get('webpc/login/index', 'webpc/login/index',['cache' => 0]); //  ,['cache' => 360000]    0 表示永久缓存

'cache' =\> 0\] 是永久缓存 \['cache' =\> 3600\] 是缓存3600秒 免费在线工具网站

相关推荐
自然 醒11 分钟前
uni-app开发微信小程序,如何使用towxml去渲染md格式和html标签格式的内容?
微信小程序·uni-app·html
酒鼎21 分钟前
学习笔记(12-02)事件循环 - 实战案例 —⭐
前端·javascript
Bigger26 分钟前
第一章:我是如何剖析 Claude Code 整体架构与启动流程的
前端·aigc·claude
竹林81832 分钟前
从“连接失败”到丝滑登录:我用 ethers.js v6 搞定 MetaMask 钱包连接的全过程
前端·javascript
oi..36 分钟前
《Web 安全入门|XSS 漏洞原理、CSP 策略与 HttpOnly 防护实践》
前端·网络·测试工具·安全·web安全·xss
UXbot1 小时前
2026年AI全链路产品开发工具对比:5款从创意到上线一站式平台深度解析
前端·ui·kotlin·软件构建·swift·原型模式
一拳不是超人1 小时前
前端工程师也要懂的服务器部署知识:从 Nginx 到 CI/CD
服务器·前端
AlkaidSTART1 小时前
TanStack Query 技术指南:异步状态管理核心实践
前端·react.js
种花家的强总1 小时前
前端项目开发/维护中降低成本的方式之一:降低耦合度
前端
Palpitate_LL1 小时前
从XSS到“RCE“的PC端利用链构建
前端·xss