Skip to content

yii框架异常处理导致的xss

字数
367 字
阅读时间
2 分钟
更新日期
10/12/2020

最近XSS扫描器发现了一些奇怪的漏洞,对一些特征归类,查询,发现是属于yii 1.x框架。

Yii是一个免费的,开源的,基于PHP的Web应用程序开发框架

虽然YII 已经发布了2.x,但1.x的使用量还是很大的

image-20200612173510976

复现

下载yii 1.x

git clone https://github.com/yiisoft/yii

运行自带的blog demo

image-20200608154544737

当请求头带有X-Requested-With: XMLHttpRequest时,并且含有yii不能识别的路径时,yii会报错,并且回显出路径,这部分也没有进行html转码。

发送如下请求体

image-20200608154902548

image-20200608154915676

image-20200608155424576

代码分析

问题发生在framework/base/CErrorHandler.php

image-20200608160035744

displayException函数在framework/console/CConsoleApplication.php中被定义,直接echo输出

image-20200608160132192

yii 2.x

vendor/yiisoft/yii2/base/Module.php,runAction方法遇到不存在的路由会抛出InvalidRouteException并将错误的路由输出

image-20200608161920575

同样在vendor/yiisoft/yii2/web/ErrorAction.php内,对于处理ajax的错误响应,没有转义html代码

image-20200608162521031

image-20200608162555330

理论上也存在1.x的漏洞,但是在web处理的最后

image-20200612173700790

会捕获这个异常并抛出一个新的异常,新异常控制的输出无法控制。

虽然捕获了这个异常,但是出现问题的异常依然在整个异常类中

image-20200612174125079

如果程序员在YII2框架中处理异常,将所有异常都输出,也有可能造成xss。

撰写

布局切换

调整 VitePress 的布局样式,以适配不同的阅读习惯和屏幕环境。

全部展开
使侧边栏和内容区域占据整个屏幕的全部宽度。
全部展开,但侧边栏宽度可调
侧边栏宽度可调,但内容区域宽度不变,调整后的侧边栏将可以占据整个屏幕的最大宽度。
全部展开,且侧边栏和内容区域宽度均可调
侧边栏宽度可调,但内容区域宽度不变,调整后的侧边栏将可以占据整个屏幕的最大宽度。
原始宽度
原始的 VitePress 默认布局宽度

页面最大宽度

调整 VitePress 布局中页面的宽度,以适配不同的阅读习惯和屏幕环境。

调整页面最大宽度
一个可调整的滑块,用于选择和自定义页面最大宽度。

内容最大宽度

调整 VitePress 布局中内容区域的宽度,以适配不同的阅读习惯和屏幕环境。

调整内容最大宽度
一个可调整的滑块,用于选择和自定义内容最大宽度。

聚光灯

支持在正文中高亮当前鼠标悬停的行和元素,以优化阅读和专注困难的用户的阅读体验。

ON开启
开启聚光灯。
OFF关闭
关闭聚光灯。

聚光灯样式

调整聚光灯的样式。

置于底部
在当前鼠标悬停的元素下方添加一个纯色背景以突出显示当前鼠标悬停的位置。
置于侧边
在当前鼠标悬停的元素旁边添加一条固定的纯色线以突出显示当前鼠标悬停的位置。