Halo 服务器请求伪造漏洞 (CVE-2022-32995)

Halo 服务器请求伪造漏洞 (CVE-2022-32995)

*一、漏洞概述 **

*1.1 漏洞简介*

·漏洞名称:Halo 服务器请求伪造漏洞

·漏洞编号:CVE-2022-32995

·漏洞类型:服务器请求伪造漏洞

·漏洞威胁等级:超危

·影响范围:Halo CMS 1.5.3

·利用条件:默认配置

*1.2 组件描述*

Halo是个人开发者的一套个人博客系统。

*1.3 漏洞描述*

Halo CMS 1.5.3 版本存在安全漏洞,该漏洞源于模板远程下载功能存在服务器请求伪造问题。

*二、漏洞复现*

*2.1 应用协议*

http

*2.2 环境搭建*

1.下载jar包到本地,在jdk目录下执行java.exe -jar halo.jar

在这里插入图片描述

*2.3 漏洞复现 **

1.分别点击主题—>安装–>远程地址,在地址栏中输入url并跟上任意压缩包名(xxx.zip)

在这里插入图片描述

2.该漏洞为通过远程下载功能来执行SSRF,可以检测主机端口是否存活,若出现“主题配置文件缺失!请确认后重试。”则该主机端口存活

在这里插入图片描述

3.若出现“Internal Server Error”,标识主机端口不存在

在这里插入图片描述
在这里插入图片描述

*三、漏洞分析*

*3.1 技术背景*

\

*3.2 代码分析*

代码对检测的url未作任何处理,导致用户可以任意的进行SSRF

  @Override
    public ThemeProperty fetch(Object source) {
        final var themeZipLink = source.toString();

        // build http request
        final var request = HttpRequest.newBuilder()
            .uri(URI.create(themeZipLink))
            .timeout(Duration.ofMinutes(2))
            .GET()
            .build();

        try {
            // request from remote
            log.info("Fetching theme from {}", themeZipLink);
            var inputStreamResponse =
                httpClient.send(request, HttpResponse.BodyHandlers.ofInputStream());
            var inputStream = inputStreamResponse.body();

            // unzip zip archive
            try (var zipInputStream = new ZipInputStream(inputStream)) {
                var tempDirectory = FileUtils.createTempDirectory();
                log.info("Unzipping theme {} to {}", themeZipLink, tempDirectory);
                unzip(zipInputStream, tempDirectory);

                // resolve theme property
                return ThemePropertyScanner.INSTANCE.fetchThemeProperty(tempDirectory)
                    .orElseThrow(() -> new ThemePropertyMissingException("主题配置文件缺失!请确认后重试。"));
            }
        } catch (InterruptedException | IOException e) {
            throw new RuntimeException("主题拉取失败!(" + e.getMessage() + ")", e);
        }
    }

}

*3.3 流量分析 **

在这里插入图片描述

*3.4 绕过方式*

\

*四、漏洞检测*

*4.1 组件版本自检*

以下版本受该漏洞影响:v 1.5.3

目前最高版本:2.8.0

*4.2 研判建议 **

在流量中观察是否有大量的请求,其中请求体带有ip/xx.zip

*参考链接*

源码下载url:https://github.com/halo-dev/halo/releases/download/v1.5.3/halo-1.5.3.jar

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
v-loading抖动的原因是由于loading时的蒙版是全屏的,导致滚动条消失,从而导致页面跳动。为了解决这个问题,可以使用element-ui的loading组件,并设置fullscreen为false来关闭全屏蒙版。这样就可以避免v-loading抖动的情况发生。 此外,你还可以在store中增加一个变量isShowLoading来控制是否显示loading。通过在mutations中定义SET_SHOWLOADING来设置isShowLoading的值,然后在页面中根据isShowLoading的值来控制loading的显示与隐藏。这样可以更加灵活地控制loading的行为,避免抖动问题的发生。 另外,如果你想要在Vue.js中实现无限滚动列表,可以考虑使用vue-infinite-loading插件。该插件可以帮助你快速创建一个无限滚动列表,并提供了丰富的配置选项。可以通过npm安装vue-infinite-loading并按照文档进行导入和使用。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [element的loading的蒙版导致滚动条消失,页面抖动](https://blog.csdn.net/weixin_42349568/article/details/114121252)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [解决连续请求,显示loading导致页面闪烁问题](https://blog.csdn.net/halo1416/article/details/116527889)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [vue-infinite-loading2.0 中文文档详解](https://download.csdn.net/download/weixin_38508549/13459913)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Tkite

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值