🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
# 十二、开放重定向漏洞 > 作者:Peter Yaworski > 译者:[飞龙](https://github.com/) > 协议:[CC BY-NC-SA 4.0](http://creativecommons.org/licenses/by-nc-sa/4.0/) ## 描述 根据 OWASP,开放重定向出现在应用接受参数并将用户重定向到该参数值,并且没有对该值进行任何校验的时候。 这个漏洞用于钓鱼攻击,便于让用户无意中浏览恶意站点,滥用给定站点的信任并将用户引导到另一个站点,恶意站点作为重定向目的地,可以将其准备成合法站点的样子,并尝试收集个人或敏感信息。 > 链接 > 查看 [OWASP 无验证重定向和转发速查表](https://www.owasp.org/index.php/Unvalidated_Redirects_and_Forwards_Cheat_Sheet) ## 示例 ### 1\. Shopify 主题安装开放重定向 难度:低 URL:`app.shopify.com/services/google/themes/preview/supply–blue?domain_name=XX` 链接:`https://hackerone.com/reports/1019622` 报告日期:2015.11.25 奖金:$500 描述: Shopify 的平台允许商店管理员自定义商店外观。为此,管理员需要安装主题。这里的漏洞时,主题安装页面会解释重定向参数,并向用户浏览器返回 301 重定向,而不验证重定向的目标。 因此,如果用户访问`https://app.shopify.com/services/google/themes/preview/supply– blue?domain_name=example.com`,它会重定向到`http://example.com/admin`。 恶意用户能够在该域部署站点,并尝试对无意识的用户执行钓鱼攻击。 > 重要结论 > 我这里再说一遍,不是所有漏洞都很复杂。这里的开放重定向只需要将重定向参数修改为外部站点。 ### 2\. Shopify 登录开放重定向 难度:中 URL:`http://mystore.myshopify.com/account/login` 报告链接:`https://hackerone.com/reports/103772` 报告日期:2015.12.6 奖金:$500 描述: 这个开放重定向非常类似于上面讨论的主题安装漏洞,但是这里。漏洞在用户登录,并且使用参数`?checkout_url`之后出现。例如: http://mystore.myshopify.com/account/login?checkout_url=.np 因此,当用户访问链接并登录,它会被重定向到: https://mystore.myshopify.com.np/ 它实际上完全不是 Shopify 的域。 ### 3\. HackerOne 间隔重定向 难度:中 URL:无 报告链接:https://hackerone.com/reports/111968 报告日期:2016.1.20 奖金:$500 描述: 这里的间隔重定向指代一些重定向,在重定向期间不发生停顿,来告诉你你正在被重定向。 HackerOne 实际上在报告中提供了该漏洞的纯语言描述: > `hackerone.com`连接被视为可信连接,包括`/zendesk_session`前面的那些。任何人都可以创建自定义的 Zendesk 账户,它会重定向到不可信的站点,并在`/redirect_to_account?state= param;`提供该功能。并且由于 Zendesk 允许账户之间的非间隔重定向,你会被引导到任何不可信站点,而没有任何警告。 > 了解 Zendesk 的原始问题之后,我们选择将带有`zendesk_session`的链接视为外部链接,点击时会渲染一个外部的图标和间隔警告页面。 所以这里,Mahmoud Jamal(是的,和 Google XSS 漏洞中的人一样)创建了`company.zendesk.com`并将: ```html <script>document.location.href = "http://evil.com";</script> ``` 通过 Zendesk 的主题编辑器添加到了头文件中。之后,传递这个链接: ``` https://hackerone.com/zendesk_session?locale_id=1&return_to=https://support.hackerone.com/ping/redirect_to_account?state=company:/ ``` 它用于重定向到生成的 Zendesk 会话。 现在,有趣的是,Mahmoud 向 Zendesk 报告了这个重定向个问题,Zendesk 说他并没有看到任何问题。所以,自然而然,它继续挖掘这个漏洞,看看如何才能利用。 > 重要结论 > 我们在应用逻辑一章中讨论了它,但它重复出现在这里,在你搜索漏洞时,要注意站点所使用的的服务,因为在你的搜索过程中,它们每个都代表一种新的攻击向量。这里,这个漏洞可以通过组合 Zendesk 的 HackerOne 使用方法,以及已知的所允许的重定向来实现。 > 此外,在你寻找 bug 时,阅读和回应你的报告的人有时不能马上理解安全影响。这就是我在漏洞报告中编写这一章的原因。如果你往前推进一小步,并且在你的报告中解释安全映像,它会确保顺利解决。 > 但是,即使是这样,公司有时候也会不理解你。如果是这样,像 Mahmoud 所做的一样,保持挖掘,并看看是否可以证明它可以利用,或者将其和其它漏洞组合来展示影响。 ## 总结 开放重定向个允许恶意攻击者将人们重定向到未知的恶意站点。就像这些例子展示的那样,寻找他们需要锐利的观察。有时会出现易于发现的`redirect_to=`,`domain_name=`,`checkout_url=`,以及其它。这种类型的漏洞依赖信任的滥用,其中受害者被诱导来访问攻击者的站点,并认为他们正在浏览他们认可的站点。 通常,当 URL 作为参数传递给 Web 请求时,你可以发现它们。要留意并玩转 URL 地址,以便观察是否接受外部站点的链接。 此外,HackerOne 间隔重定向展示了二者的重要性。当你寻找漏洞时,识别站点所用的工具和服务,以及有时在被认可和接受之前,你需要坚持并清晰展示漏洞。