51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 4139|回复: 0
打印 上一主题 下一主题

白盒测试中xpath注入漏洞

[复制链接]
  • TA的每日心情
    开心
    2021-4-25 14:19
  • 签到天数: 13 天

    连续签到: 1 天

    [LV.3]测试连长

    跳转到指定楼层
    1#
    发表于 2021-4-20 13:31:29 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    1、什么是XPath注入漏洞?

    XPath是一种用来在内存中导航整个XML树的语言,它使用路径表达式来选取XML文档中的节点或者节点集。

    XPath注入是指程序使用外部输入动态构造用于从XML数据库检索数据的XPath表达式,但它没有过滤或错误地过滤该输入,这使攻击者可以控制查询的结构。攻击者可以控制从XML数据库中选择的信息,并可能使用该功能来控制应用程序流,修改逻辑,检索未经授权的数据或绕过重要检查(例如身份验证)。


    2、XPath注入漏洞的构成条件有哪些?

    ①数据是从不可靠的来源(包括但不局限于不可靠用户的输入信息或是不可靠用户可能更改的文件)进入应用程序的;

    ②用户输入未经过验证,被查询语句直接使用并执行。


    3、XPath注入漏洞会造成哪些后果?

    关键词:绕过验证;读取重要数据;

    ①控制应用程序流程(例如绕过身份验证),从而进行一些未授权的行为;

    ②攻击者可以读取未授权的XML内容。


    4、如何防范修补XPath注入漏洞?

    ①使用参数化的XPath查询(例如使用XQuery)。这有助于确保数据平面和控制平面之间的分离;

    ②对用户输入的数据提交到服务器上端,在服务端正式处理这批数据之前,对提交数据的合法性进行验证。检查提交的数据是否包含特殊字符,对特殊字符进行编码转换或替换、删除敏感字符或字符串,如过滤[ ] ‘ “ and or 等全部过滤,像单双引号这类,可以对这类特殊字符进行编码转换或替换;

    ③通过加密算法,对于数据敏感信息和在数据传输过程中加密。


    5、XPath注入漏洞样例:


    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-4-25 18:01 , Processed in 0.066113 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

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