一次服务器被传webshell事件溯源

背景

web服务器使用SiteServer开源CMS为建站模板,该类cms属于漏洞高发区,频频会爆出高危漏洞。这次的应该是个在野0day。

起因

阿里云安骑士告警


webshell告警

溯源过程

  1. 可以看到阿里云安骑士报了存在服务器存在webshell,访问该链接,显示403,应该是触发了上传目录下可读可写不可执行的安全策略。我们取得了相关服务器的权限之后,在主机上进行漏洞影响范围和攻击溯源。
  2. 登上服务器首先对系统安全进行排查,查看隐藏用户以及计划人物以及登录日志,初步判断攻击者并没有通过webshell提升到系统的权限。
  3. 从服务器dump下机器最近10天的web访问记录到本地进行溯源分析。
  4. 找到攻击payload如下:
    payload

    三条payload分别对应获取UserNamePasswordPasswordSalt
http://www.xxxx.cn/SiteServer/Ajax/ajaxCmsService.aspx?type=GetTitles&publishmentSystemId=1&nodeId=1&title=a%27,0)%20%3E%200%20union%20select%20TOP%202%20Username%20from%20bairong_Administrator--
http://www.xxxx.cn/SiteServer/Ajax/ajaxCmsService.aspx?type=GetTitles&publishmentSystemId=1&nodeId=1&title=a%27,0)%20%3E%200%20union%20select%20TOP%201%20Password%20from%20bairong_Administrator--%20
http://www.xxxx.cn/SiteServer/Ajax/ajaxCmsService.aspx?type=GetTitles&publishmentSystemId=1&nodeId=1&title=a%27,0)%20%3E%200%20union%20select%20TOP%202%20PasswordSalt%20from%20bairong_Administrator--

获取了管理员用户的用户名、密码密文以及密钥,解密之后可登陆管理后台。http://www.xxxx.cn/siteserver/login.aspx。通过日志可以看到,攻击者在登录管理后台后成功上传了木马文件。

upload

上传接口在后台就不展示了。简单的双写绕过文件后缀检测。
双写绕过

因为触发了之前配置的可读可写不可执行的策略,所以攻击者上传的木马访问是403,无法进一步攻击。
403

之后跟进攻击者的使用的ip以及上传木马时间节点之后的日志,并未发现有其他成功的进一步攻击事件。

攻击过程概述

此次攻击事件攻击链由一个未授权接口的sql注入以及后台文件上传漏洞构成。以下日志分析的时间为GMT+0,国内时间应该在此基础上加8小时:

  • 2020-10-19 18:44 IP为128.14.16.23攻击者通过siteserver的一个未授权访问接口的sql注入获取了管理员用户信息。
  • 2020-10-22 09:33 IP为198.176.51.185的攻击者通过siteserver的一个未授权访问接口的sql注入获取了管理员用户信息。这两次从请求时间间隔特征可以大致判断攻击已经自动化。
  • 2020-10-22 09:31 IP为128.14.16.23的攻击者通过后台的文件上传漏洞上传了avator.aspx的网站木马文件。
  • 2020-10-22 09:34 IP为198.176.51.185的攻击者通过后台的文件上传漏洞上传了avator.aspx的网站木马文件。
  • (北京时间)2020-10-22 17:31 阿里云安骑士预警存在webshell文件。

影响范围:

攻击者可以获取到该站点siteserver应用管理员
攻击者可以访问到对应的siteserver数据库数据

漏洞分析

通过整个攻击溯源分析可知,对应的攻击链为:接口未授权访问-->sql注入-->文件上传突破。其中接口未授权访问是最开始的一点,要在源头切断攻击链是最高效的。因此我们通过对日志的统计,发现该接口并不常用,20天没有正常的访问记录,便临时选择关闭该接口来暂时确保安全。此次主要针对sql注入的漏洞从代码层面看一看。

代码分析

从日志可以看到出现问题的是SiteServer/Ajax/ajaxCmsService.aspx文件调用的是一个编译好的dll文件。

aspx

dll文件

反编译改文件找到对应的代码块:
get请求

可以看到对应的http请求的函数为GetTitles出现sql注入的参数是title,该参数没有经过任何处理直接传到了执行sql的GetValueListByStartString函数中,定位到该函数:
sql函数

title参数对应这的startString参数。该参数也是没有经过任何处理就被传入GetInStr函数。查看该函数:
GetInStr

这个只是拼接一下两个参数并没有其他处理,所以回到上个执行sql的函数可以看到,参考一条注入日志,他所执行的sql语句为:

#SQL注入日志
http://www.xxxx.cn/SiteServer/Ajax/ajaxCmsService.aspx?type=GetTitles&publishmentSystemId=1&nodeId=1&title=a',0) > 0 union select TOP 2 PasswordSalt from bairong_Administrator--
#实际执行的SQL语句
SELECT xxx FROM *** WHERE NodeID = 1 AND CHARINDEX('a',0) > 0 union select TOP 2 PasswordSalt from bairong_Administrator-- ', 'Title') > 0

可以看到看一眼源码的话随意就可以成功注入。根据源码可知,此处都是直接拼接sql,解决方案就是不应该拼接sql,使用ORM的方式。

总结

此次攻击可以看到攻击链的源头是未授权访问,对这个接口以及同文件夹下的其他几个接口进行测试可知都存在未授权访问的情况,有可能也存在注入的漏洞。对日志分析也不存在这些接口的正常业务请求,推测是给其他接口内部调用,不应该对外开放。且这次虽然被上传了webshell但是因为之前的安全策略的完备,抵御住了攻击者下一步的攻击,减少了安全事件带来的损失。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351

推荐阅读更多精彩内容