CWE-180:不正确的行为顺序:在规范之前验证
查看自定义信息:
该表显示了与该弱点相关的弱点和高级类别。这些关系定义为childof,parentof,ementof,并深入了解可能存在于较高和较低抽象水平的类似项目。此外,定义了诸如Peerof和Canalsobe之类的关系,以显示用户可能想要探索的类似弱点。
与观点“研究概念”相关(CWE-1000)
该清单显示了可能出现的弱点的可能区域。这些可能适用于特定的命名语言,操作系统,体系结构,范式,技术或一类此类平台。该平台与给定弱点出现在该实例的频率一起列出。
语言 班级:不是特定语言的(不确定的患病率)
该表指定与弱点相关的不同个人后果。该范围确定了违反的应用程序安全区域,而影响描述了如果对手成功利用这一弱点,就会产生负面的技术影响。其可能性提供了有关预期相对于列表中其他后果的特定后果的可能性的信息。例如,可能会利用弱点来实现一定的影响,但很可能会利用它来实现不同的影响。
示例1 以下代码尝试通过对允许列表进行检查,然后返回规范路径来验证给定输入路径。在这种特定情况下,如果路径以字符串“/safe_dir/”开头,则认为该路径是有效的。
(不良代码)
示例语言:爪哇
字符串路径= getInputPath();
if(path.startswith(“/safe_dir/”)) {
文件f =新文件(路径); }返回f.GetCanonicalPath(); 上述代码的问题在于,验证步骤发生在发生规范化之前。攻击者可以提供“/safe_dir/../”的输入路径,该路径将通过验证步骤。但是,规范化过程将双点视为父级目录的遍历,因此何时将路径变为“/”。 为了避免此问题,应在进行规范化后进行验证。在这种情况下,规范化发生在文件对象的初始化期间。下面的代码解决了问题。
(好代码)
示例语言:爪哇
字符串路径= getInputPath();
文件f =新文件(路径); if(f.getCanonicalPath()。startswith(“/safe_dir/”)) {
返回f.GetCanonicalPath(); }
此成员关系表显示了其他CWE类别和视图,将此弱点称为成员。该信息通常可用于理解弱点适合外部信息源的何处。
提供更多信息 - 请选择其他过滤器。
|
使用共同弱点枚举(CWE)和本网站的相关参考使用条款。CWE由美国国土安全部(DHS)网络安全和基础设施安全局(CISA),由国土安全系统工程和开发研究所(HSSEDI)由manbetx客户端首页(MITER)。版权所有©2006–2023,Miter Comanbetx客户端首页rporation。CWE,CWSS,CWRAF和CWE徽标是Miter Corporation的商标。manbetx客户端首页 |