- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们在忘记密码页面上有一个安全问题被标记为:
ISS-0003938 Web Inspect Open Medium Suspicious Files Found in Recursive Directory ****** Remove any unnecessary pages from the web server If any files are necessary restrict access to those that are not supposed to be publicly accessible Remove any backup files and temporary files that were on the server for development testing Please remove backup files alternative login files, files that contain functionality that are depreciated and any short cut files that developers use.
被标记的文件是/js/pmailer_minimal.js
,因为.js
文件中有如下内容。
url: URL + '/login/forgot-password/request/'+ username,
通过使用该信息,攻击者随后能够开始枚举用户名,直到他们从响应中获得成功消息。
这个问题的最佳解决方案是什么?我们会改变我们的 react 吗?我们是否限制重试次数?还有哪些其他解决方案?
还应该考虑的是,如果攻击者拥有用户名,他就可以尝试暴力攻击。
我正在寻找尽可能多的建议来解决这个威胁。
最佳答案
我将为此添加渗透测试人员的观点。
获取公司人员名单非常容易。只需谷歌 LinkedIn 等。我什至有一些潜在的密码(密码转储、愚蠢的密码,如 Pa$$w0rd、公司名称或其他常见模式)。
问题是将这些应用于公开的随机网络应用程序。用户名格式是 first.lastname、email、firstinitiallastname 还是其他格式。我将采用这些并尝试使用一些潜在密码的所有用户。目标是获得一次有效登录。然后就可以很容易地从应用本身中提取真实用户的完整列表。
在登录页面上给出一个通用的答案确实让我们的努力受挫。如果我可以获得正确的用户名,我最多可以为每个用户尝试大约 24 个密码(每个用户每小时一个密码,以尝试避免锁定)。在尝试一天后我没有成功登录的组织并不多。
如果我不能确定用户名是否正确,那么我必须为每个可能的密码尝试用户名的每个组合。因此,我可能只能为每个潜在用户尝试 3-4 个密码,否则会变得太费力。因此,除非用户选择非常愚蠢的密码,否则我可能不会进入该应用程序。
有时您可以根据应用程序的其他部分检查用户名,尤其是密码重置功能。对于抽查很有用,但不是暴力破解,因为它通常会向用户发送电子邮件,并且可能会锁定帐户,直到密码被重置。太多这些通常会提醒 IT 发生了某些事情。
就像其他人提到的那样,我将把它列为一个漏洞。如果我开始使用它,它就会出现在报告中。如果没有,我会告诉 IT 人员,但将其排除在报告之外。试图找到任何东西添加到报告中的较小的渗透测试者确实会将其标记为关键并将其夸大。
我通常推荐的解决方案是为失败登录总数添加一个阈值。锁定在每个用户的基础上效果很好,因此在一段时间内登录失败很多。为尝试对所有用户输入密码的人添加其他内容,例如在一段时间内 XX 唯一失败的用户登录。总会有一些基本的噪音,但暴力攻击很快就会变得非常明显。
关于javascript - 防止攻击者获取系统的用户名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38219263/
我有这个代码: System.err.print("number of terms = "); System.out.println(allTerms.size()); System.err
我有以下问题:在操作系统是 Linux 的情况下和在操作系统是 MacOs 的情况下,我必须执行不同的操作。 所以我创建了以下 Ant 脚本目标: /u
我正在调用 system("bash ../tools/bashScript\"This is an argument!\"&"),然后我正在调用 close(socketFD) 直接在 system
使用最初生成的随机元素来约束随机数组的连续元素是否有效。 例如:我想生成一组 10 个 addr、size 对来模拟典型的内存分配例程并具有如下类: class abc; rand bit[5:0
我正在创建一个必须使用system(const char*)函数来完成一些“繁重工作”的应用程序,并且我需要能够为用户提供粗略的进度百分比。例如,如果操作系统正在为您移动文件,它会为您提供一个进度条,
我即将编写一些项目经理、开发人员和业务分析师会使用的标准/指南和模板。目标是更好地理解正在开发或已经开发的解决方案。 其中一部分是提供有关记录解决方案的标准/指南。例如。记录解决/满足业务案例/用户需
在开发使用压缩磁盘索引或磁盘文件的应用程序时,其中部分索引或文件被重复访问(为了论证,让我们说一些类似于 Zipfian 分布的东西),我想知道什么时候足够/更好地依赖操作系统级缓存(例如,Debia
我们编写了一个 powershell 脚本,用于处理来自内部系统的图像并将其发送到另一个系统。现在,业务的另一部分希望加入其中,对数据进行自己的处理,并将其推送到另一个系统。打听了一下,公司周围有几个
我正在尝试朗姆酒我的应用程序,但我收到以下错误:System.Web.HttpUnhandledException:引发了“System.Web.HttpUnhandledException”类型的异
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
所以我在其他程序中没有收到此错误,但我在这个程序中收到了它。 这个程序是一个我没有收到错误的示例。 #include int main() { system("pause"); } // en
我在 c# System.URI.FormatExption 中遇到问题 为了清楚起见,我使用的是 Segseuil 的 Matlab 方法,并且它返回一个图片路径 result。我想为其他用户保存此
我正在尝试像这样设置文本框的背景色: txtCompanyName.BackColor = Drawing.Color.WhiteSmoke; 它不喜欢它,因为它要我在前面添加系统,例如: txtCo
请帮助我解决 System.StackOverflowException我想用 .aspx 将记录写入数据库我使用 4 层架构来实现这一切都正常但是当我编译页面然后它显示要插入数据的字段时,当我将数据
我使用了一些通常由系统调用的API。 因此,我将 android:sharedUserId="android.uid.system" 添加到 manifest.xml, 并使用来自 GIT 的 And
我正在尝试创建一个小型应用程序,它需要对/system 文件夹进行读/写访问(它正在尝试删除一个文件,并创建一个新文件来代替它)。我可以使用 adb 毫无问题地重新挂载该文件夹,如果我这样做,我的应用
我想从没有 su 的系统 priv-app 将/system 重新挂载为 RW。如何以编程方式执行此操作?只会用 Runtime.getruntime().exec() 执行一个 shell 命令吗
我正在尝试制作一个带有登录系统的程序我对此很陌生,但我已经连续工作 8 个小时试图解决这个问题。这是我得到的错误代码 + ServerVersion 'con.ServerVersion' threw
当我“构建并运行”Code::Blocks 中的程序时,它运行得非常好!但是当我从“/bin”文件夹手动运行它时,当它试图用 system() 调用“temp.bat”时,它会重置。这是为什么?它没有
我想使用 system/pipe 命令来执行具有特殊字符的命令。下面是示例代码。通过系统/管道执行命令后,它通过改变特殊字符来改变命令。我很惊讶地看到系统命令正在更改作为命令传递的文本。 run(ch
我是一名优秀的程序员,十分优秀!