CWE-650: Trusting HTTP Permission Methods on the Server Side

Variant Incomplete Simple

CWE版本: 4.18

更新日期: 2025-09-09

弱点描述

The server contains a protection mechanism that assumes that any URI that is accessed using HTTP GET will not cause a state change to the associated resource. This might allow attackers to bypass intended access restrictions and conduct resource modification and deletion attacks, since some applications allow GET to modify state.

扩展描述

The HTTP GET method and some other methods are designed to retrieve resources and not to alter the state of the application or resources on the server side. Furthermore, the HTTP specification requires that GET requests (and other requests) should not have side effects. Believing that it will be enough to prevent unintended resource alterations, an application may disallow the HTTP requests to perform DELETE, PUT and POST operations on the resource representation. However, there is nothing in the HTTP protocol itself that actually prevents the HTTP GET method from performing more than just query of the data. Developers can easily code programs that accept a HTTP GET request that do in fact create, update or delete data on the server. For instance, it is a common practice with REST based Web Services to have HTTP GET requests modifying resources on the server side. However, whenever that happens, the access control needs to be properly enforced in the application. No assumptions should be made that only HTTP DELETE, PUT, POST, and other methods have the power to alter the representation of the resource being accessed in the request.

常见后果

影响范围: Access Control

技术影响: Gain Privileges or Assume Identity

说明: An attacker could escalate privileges.

影响范围: Integrity

技术影响: Modify Application Data

说明: An attacker could modify resources.

影响范围: Confidentiality

技术影响: Read Application Data

说明: An attacker could obtain sensitive information.

潜在缓解措施

阶段: System Configuration

描述: Configure ACLs on the server side to ensure that proper level of access control is defined for each accessible resource representation.

引入模式

阶段 说明
Architecture and Design -
Implementation -
Operation -

适用平台

编程语言
Not Language-Specific (Undetermined)
关键信息

CWE ID: CWE-650

抽象级别: Variant

结构: Simple

状态: Incomplete

利用可能性: High

相关弱点